从 View 获取值到另一个控制器
Get value from View to another controller
我有一个独特的 controller
,我可以在其中控制我的所有视图,所以从这里开始我遇到了问题。发送数据进行登录后,我需要获取发送的值。例如,我有这个控制器:HomeController
,在这个控制器中我有四个 ActionResult
:
ActionResult Index
ActionResult Login
ActionResult Cuotas
ActionResult LogOff
因此,当用户登录时,我需要在此处获取用户名以验证是否已从我的数据库连接
家庭控制器:
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Login(string uname, string psw)
{
try
{
ViewData["uname"] = uname;
ViewData["psw"] = psw;
ConexionSQL sql = new ConexionSQL();
var usuario = sql.login(uname, psw);
var existencia = sql.usuarioOCobrador(uname, psw);
if (existencia[0].usuario == "USUARIO")
{
var caracteres = Convert.ToString(psw);
var pruebaUsuario = sql.datos(uname);
if (pruebaUsuario[0].clave == caracteres)
{
return View("Cuotas", usuario);
}
else
{
ViewBag.Contra = "Contraseña incorrecta.";
}
}
else if (existencia[0].usuario == "COBRADOR")
{
return RedirectToAction("Cuotas", "Home", usuario);
}
else
{
ViewBag.Usu = "Usuario incorrecto o usted no tiene los permisos para ingresar al sistema. Comuníquese con el área pertinente o el Departamento de Sistemas.";
}
}
catch (SqlException ex)
{
throw ex;
}
return View("Index");
}
public ActionResult LogOff(string uname)
{
ConexionSQL conexionSQL = new ConexionSQL();
conexionSQL.updateConectado(uname, false);
FormsAuthentication.SignOut();
Session.Abandon();
return RedirectToAction("Index", "Home");
}
public ActionResult Cuotas()
{
ConexionSQL sql = new ConexionSQL();
string uname = string.Empty;
string psw = string.Empty;
//Get your ViewData variables here
if (ViewData["uname"] != null)
{
uname = Convert.ToString(ViewData["uname"]);
}
if (ViewData["psw"] != null)
{
psw = Convert.ToString(ViewData["psw"]);
}
var usuario = sql.datosCob(uname);
if (usuario[0].conectado == false)
{
return RedirectToAction("Index", "Home");
}
else
{
return RedirectToAction("Cuotas", "Home");
}
}
}
索引查看,这里是登录:
<form class="modal-content animate" onsubmit="return control()" method="post" action="@Url.Action("Login", "Home")">
<div class="imgcontainer">
<span onclick="document.getElementById('id01').style.display='none'" class="close" title="Cerrar">×</span>
<img src="~/Images/00.png" alt="Logo" class="avatar"/>
</div>
<div class="container">
<label for="uname"><b>Usuario:</b></label>
<input type="text" id="uname" placeholder="Ingrese usuario..." name="uname" onkeypress="return soloLetras(event)"/>
<label for="psw"><b>Contraseña:</b></label>
<input type="password" id="psw" placeholder="Ingrese contraseña..." name="psw" onkeypress="return soloNumeros(event)"/>
<button type="submit">Iniciar sesión</button>
</div>
</form>
但是 uname
总是 null
,我的代码有什么问题?
如果我理解正确的话,你需要先把你的 uname
post 放到你的 Login
方法中,然后你需要这个变量你的 Cuotas
方法提交表单时的相同请求?如果是这种情况,那么您必须使用 Session
将您的变量从一个控制器操作持久化到另一个控制器操作。您的表单操作是 Login
方法而不是 Cuotas
方法,因此您的 FormCollection
将始终为空。所以在你的情况下,它看起来像:
public ActionResult Login(string uname, string psw)
{
Response.AppendHeader("Cache-Control", "no-store");
try
{
//Set your variables here to passed to next action
Session["uname"] = uname;
Session["psw"] = psw;
ConexionSQL sql = new ConexionSQL();
var usuario = sql.login(uname, psw);
var existencia = sql.usuarioOCobrador(uname, psw);
if (existencia[0].usuario == "USUARIO")
{
var caracteres = Convert.ToString(psw);
var pruebaUsuario = sql.datos(uname);
if (pruebaUsuario[0].clave == caracteres)
{
sql.updateConectado(uname, true);
return RedirectToAction("Cuotas", "Home");
}
else
{
ViewBag.Contra = "Contraseña incorrecta.";
}
}
else if (existencia[0].usuario == "COBRADOR")
{
sql.updateConectado(uname, true);
return RedirectToAction("Cuotas", "Home");
}
else
{
ViewBag.Usu = "Usuario incorrecto o usted no tiene los permisos para ingresar al sistema. Comuníquese con el área pertinente o el Departamento de Sistemas.";
}
}
catch (SqlException ex)
{
throw ex;
}
return View("Index");
}
您可以像这样在 Cuotas
方法中获取它们:
public ActionResult Cuotas()
{
ConexionSQL sql = new ConexionSQL();
string uname = string.Empty;
string psw = string.Empty;
//Get your ViewData variables here
if (Session["uname"] != null)
{
uname = Convert.ToString(Session["uname"]);
}
if (Session["psw"] != null)
{
psw = Convert.ToString(Session["psw"]);
}
var usuario = sql.datosCob(uname);
if (usuario[0].conectado == false)
{
return RedirectToAction("Index");
}
else
{
return View("Cuotas");
}
}
我有一个独特的 controller
,我可以在其中控制我的所有视图,所以从这里开始我遇到了问题。发送数据进行登录后,我需要获取发送的值。例如,我有这个控制器:HomeController
,在这个控制器中我有四个 ActionResult
:
ActionResult Index
ActionResult Login
ActionResult Cuotas
ActionResult LogOff
因此,当用户登录时,我需要在此处获取用户名以验证是否已从我的数据库连接
家庭控制器:
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Login(string uname, string psw)
{
try
{
ViewData["uname"] = uname;
ViewData["psw"] = psw;
ConexionSQL sql = new ConexionSQL();
var usuario = sql.login(uname, psw);
var existencia = sql.usuarioOCobrador(uname, psw);
if (existencia[0].usuario == "USUARIO")
{
var caracteres = Convert.ToString(psw);
var pruebaUsuario = sql.datos(uname);
if (pruebaUsuario[0].clave == caracteres)
{
return View("Cuotas", usuario);
}
else
{
ViewBag.Contra = "Contraseña incorrecta.";
}
}
else if (existencia[0].usuario == "COBRADOR")
{
return RedirectToAction("Cuotas", "Home", usuario);
}
else
{
ViewBag.Usu = "Usuario incorrecto o usted no tiene los permisos para ingresar al sistema. Comuníquese con el área pertinente o el Departamento de Sistemas.";
}
}
catch (SqlException ex)
{
throw ex;
}
return View("Index");
}
public ActionResult LogOff(string uname)
{
ConexionSQL conexionSQL = new ConexionSQL();
conexionSQL.updateConectado(uname, false);
FormsAuthentication.SignOut();
Session.Abandon();
return RedirectToAction("Index", "Home");
}
public ActionResult Cuotas()
{
ConexionSQL sql = new ConexionSQL();
string uname = string.Empty;
string psw = string.Empty;
//Get your ViewData variables here
if (ViewData["uname"] != null)
{
uname = Convert.ToString(ViewData["uname"]);
}
if (ViewData["psw"] != null)
{
psw = Convert.ToString(ViewData["psw"]);
}
var usuario = sql.datosCob(uname);
if (usuario[0].conectado == false)
{
return RedirectToAction("Index", "Home");
}
else
{
return RedirectToAction("Cuotas", "Home");
}
}
}
索引查看,这里是登录:
<form class="modal-content animate" onsubmit="return control()" method="post" action="@Url.Action("Login", "Home")">
<div class="imgcontainer">
<span onclick="document.getElementById('id01').style.display='none'" class="close" title="Cerrar">×</span>
<img src="~/Images/00.png" alt="Logo" class="avatar"/>
</div>
<div class="container">
<label for="uname"><b>Usuario:</b></label>
<input type="text" id="uname" placeholder="Ingrese usuario..." name="uname" onkeypress="return soloLetras(event)"/>
<label for="psw"><b>Contraseña:</b></label>
<input type="password" id="psw" placeholder="Ingrese contraseña..." name="psw" onkeypress="return soloNumeros(event)"/>
<button type="submit">Iniciar sesión</button>
</div>
</form>
但是 uname
总是 null
,我的代码有什么问题?
如果我理解正确的话,你需要先把你的 uname
post 放到你的 Login
方法中,然后你需要这个变量你的 Cuotas
方法提交表单时的相同请求?如果是这种情况,那么您必须使用 Session
将您的变量从一个控制器操作持久化到另一个控制器操作。您的表单操作是 Login
方法而不是 Cuotas
方法,因此您的 FormCollection
将始终为空。所以在你的情况下,它看起来像:
public ActionResult Login(string uname, string psw)
{
Response.AppendHeader("Cache-Control", "no-store");
try
{
//Set your variables here to passed to next action
Session["uname"] = uname;
Session["psw"] = psw;
ConexionSQL sql = new ConexionSQL();
var usuario = sql.login(uname, psw);
var existencia = sql.usuarioOCobrador(uname, psw);
if (existencia[0].usuario == "USUARIO")
{
var caracteres = Convert.ToString(psw);
var pruebaUsuario = sql.datos(uname);
if (pruebaUsuario[0].clave == caracteres)
{
sql.updateConectado(uname, true);
return RedirectToAction("Cuotas", "Home");
}
else
{
ViewBag.Contra = "Contraseña incorrecta.";
}
}
else if (existencia[0].usuario == "COBRADOR")
{
sql.updateConectado(uname, true);
return RedirectToAction("Cuotas", "Home");
}
else
{
ViewBag.Usu = "Usuario incorrecto o usted no tiene los permisos para ingresar al sistema. Comuníquese con el área pertinente o el Departamento de Sistemas.";
}
}
catch (SqlException ex)
{
throw ex;
}
return View("Index");
}
您可以像这样在 Cuotas
方法中获取它们:
public ActionResult Cuotas()
{
ConexionSQL sql = new ConexionSQL();
string uname = string.Empty;
string psw = string.Empty;
//Get your ViewData variables here
if (Session["uname"] != null)
{
uname = Convert.ToString(Session["uname"]);
}
if (Session["psw"] != null)
{
psw = Convert.ToString(Session["psw"]);
}
var usuario = sql.datosCob(uname);
if (usuario[0].conectado == false)
{
return RedirectToAction("Index");
}
else
{
return View("Cuotas");
}
}