【发布时间】:2017-05-31 08:03:05
【问题描述】:
首先,我是 Umbraco 的新手,所以如果您看到一些基本错误,请不要评判我。
所以我目前正在创建一个登录表单,他进入数据库(检查用户名和密码)并读取他返回的值并让他Cannot bind source type Umbraco.Web.Models.RenderModel to model type Repower.Cms.Umbraco.Models.Test.
这是我的 HTML:
@inherits Umbraco.Web.Mvc.UmbracoViewPage<Repower.Cms.Umbraco.Models.Test>
@{
Layout = "Master.cshtml";
}
<style type="text/css">
.btnStyle {
border: thin solid #000000;
line-height: normal;
width: 80px;
}
</style>
@using (Html.BeginForm("Test", "MembersProtectedPage", FormMethod.Post))
{
<div class="fontStyle">
<center>
<table style="margin-top: 100px;margin-left:150px">
<tr style="height:30px">
<td align="right">
@Html.LabelFor(m => m.User)
</td>
<td style="width:200px" align="right">
@Html.TextBoxFor(m => m.User)
</td>
<td style="width:250px;color:Red" align="left">
@Html.ValidationMessageFor(m => m.User)
</td>
</tr>
<tr style="height:30px">
<td align="right">
@Html.LabelFor(m => m.Password)
</td>
<td align="right">
@Html.PasswordFor(m => m.Password)
</td>
<td style="width:250px;color:Red" align="left">
@Html.ValidationMessageFor(m => m.Password)
</td>
</tr>
<tr style="height:30px">
<td colspan="2" align="center">
<input type="submit" value="Sign In" class="btnStyle" />
</td>
</tr>
</table>
</center>
</div>
}
这是我的模特:
public class Test : RenderModel
{
public Test() : this(new UmbracoHelper(UmbracoContext.Current).TypedContent(UmbracoContext.Current.PageId)) { }
public Test(IPublishedContent content, CultureInfo culture) : base(content, culture) { }
public Test(IPublishedContent content) : base(content) { }
string connString = ConfigurationManager.ConnectionStrings["connectionStringName"].ConnectionString;
SqlConnection conn;
SqlCommand sqlcomm;
public string User { get; set; }
public string Password { get; set; }
public bool IsUserExist(string emailid, string password)
{
bool flag = false;
conn = new SqlConnection(connString);
conn.Open();
sqlcomm = new SqlCommand();
sqlcomm.Connection = conn;
sqlcomm.CommandType = System.Data.CommandType.StoredProcedure;
sqlcomm.CommandText = "dbo.uspLogin";
sqlcomm.Parameters.AddWithValue("@pLoginName", User);
sqlcomm.Parameters.AddWithValue("@pPassword", Password);
SqlParameter retval = sqlcomm.Parameters.Add("@RESULT", SqlDbType.VarChar);
retval.Direction = ParameterDirection.ReturnValue;
sqlcomm.ExecuteNonQuery(); // MISSING
string retunvalue = (string)sqlcomm.Parameters["@RESULT"].Value;
switch (retunvalue)
{
case "0":
flag = true;
break;
case "1":
flag = false;
break;
case "2":
flag = false;
break;
default:
flag = false;
break;
}
return flag;
}
}
这是我的控制器:
public class TestController : Controller
{
public ViewResult Login()
{
return View();
}
[HttpPost, ValidateInput(false)]
public ActionResult Login(Test model)
{
if (ModelState.IsValid)
{
if (model.IsUserExist(model.User, model.Password))
{
ViewBag.UserName = model.User;
FormsAuthentication.RedirectFromLoginPage(model.User, false);
}
else
{
ModelState.AddModelError("", "Username or Password Incorrect.");
}
}
return View(model);
}
}
所以我继承了 RenderModel,因为之前我的错误是“传递到字典中的模型项的类型为 Repower.Cms.Umbraco.Models.Test”,但该字典需要“Umbraco.Web”类型的模型项。模型.RenderModel'。” 所以我改变了它(在互联网上搜索了很多),现在我得到了这个错误。
其余的代码也正确吗?我访问数据库和所有内容的方式?我期待来自数据库的返回值(不知道这是否正确)
有人可以帮助我吗? 我今天需要完成这项工作。
提前致谢
【问题讨论】:
标签: sql asp.net-mvc model controller umbraco