Razor和JS麻烦:检查用户是否存在

时间:2017-08-12 18:13:23

标签: javascript asp.net razor

我做错了什么?我试图验证用户不存在。我无法弄清楚如何发送@ email1或@ 0。我尝试了几种方法。当我对WHERE CLAUSE进行硬编码时,我可以让它工作。例如,我知道的电子邮件是doug@fresh.com。这有效:"var userCheck = "SELECT * FROM USR WHERE EMAIL = 'doug@fresh.com'".Count()

这些有效:我尝试了var userCheck = "SELECT * FROM USR WHERE EMAIL = " +email1.Count();"var userCheck = "SELECT * FROM USR WHERE EMAIL = @0".Count()

我是否必须将email1作为参数传递???

ASP.NET- Razor:

@{
    Page.Title = "Register";
    var minPass = 2;
    var maxPass = 100;
    var email1 = "";
    var pass1 = "";
    var db = Database.Open("Resume");
    var userCheck = "SELECT * FROM USR WHERE EMAIL = " +email1;
    var userInsert = "INSERT INTO USR (EMAIL, PSWD) VALUES (@0, @1)";


    if(IsPost) {
        email1 = Request.Form["email1"];
        pass1 = Request.Form["pass1"];
        db.Execute(userInsert, email1, pass1);
        Response.Redirect("~/Default");
    }
}

使用Javascript:

var error = "";
var email1 = document.getElementById('em100').value;
var email2 = document.getElementById('em101').value;
var pass1 = document.getElementById('pw100').value;
var pass2 = document.getElementById('pw101').value;

if (@userCheck > 0) error += "</br>Email already exists."; // ?????????????????
if (!document.getElementById('em100').checkValidity()) error += "</br>Emails are not valid.";
if (email1 !== email2) error += "</br>Emails do not match.";
if (pass1 !== pass2) error += "</br>Passwords do not match.";
if (pass1.length < minPass || pass1.length > maxPass) error += "</br>Password must be minPass - maxPass characters.";

1 个答案:

答案 0 :(得分:0)

我想评论一下我的做法是完全错误的。

我不再使用Javascript进行验证,而只使用ASP.NET Razor。

对于那些在类似事情上挣扎的人,下面是我的解决方案:

请务必加入WebSecurity.InitializeDatabaseConnection("ResumeLink", "UserProfile", "UserId", "Email", true);

@{ 
    var username = "";
    var password = "";
    var confirmPassword = "";
    var regMsg = "";
    var minPass = 2;
    var maxPass = 5;


    if (!IsPost) {
    if (WebSecurity.IsAuthenticated) {
        regMsg = String.Format("You are already logged in. (User name: {0})", WebSecurity.CurrentUserName);
        }
    }

    if (IsPost){
    WebSecurity.Logout();    
    username = Request["username"];
    password = Request["password"];
    confirmPassword = Request["confirmPassword"];

    try {
        var mail = new System.Net.Mail.MailAddress(username);
    } catch {
        regMsg += "Invalid email format.";
    }

    //Validation.Add("username", Validator.Regex(@"^[A-Za-z0-9._%+-]+@@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}$", regMsg += "Invalid email format."));
    if (password != confirmPassword) {regMsg += "</br>Passwords don't match.";}
    if (WebSecurity.UserExists(username)) {regMsg += String.Format("</br>User '{0}' already exists.", username);}
    if (password.Length < minPass || password.Length > maxPass) {regMsg += "</br>Password doesn't meet length requirement.";}
    if (regMsg == "") {
        WebSecurity.CreateUserAndAccount(username,password,null,false);
        regMsg = String.Format("{0} created.", username);
        Response.Write("Registration Successful!");
        Response.Redirect("~/Default.cshtml");
        }
    }
}

<style>header {visibility: hidden;}</style>
<body>
    <div>
        <h1>Register</h1>
        <form method="post">
            <p>
                @if(regMsg != ""){
                    <span class="errorMessage">@Html.Raw(regMsg)</span>
                }
            </p>

            <p>
                <label for="username">Email Address:</label><br/>
                <input type="text" name="username" id="username" value='@Request["username"]' />
            </p>
            <p>
                <label for="password">Password @minPass-@maxPass Characters:</label><br/>
                <input type="password" name="password" id="password" value="" />
            </p>   
            <p>
                <label for="confirmPassword">Confirm Password:</label><br/>
                <input type="password" name="confirmPassword" id="confirmPassword" value="" />
            </p>
            <p>
                <input type="submit" value="Submit" />
                <input type="button" value="Cancel" onclick="javascript:location.href='Default.cshtml'" />
            </p>   
            <p>
            </p>
        </form>
    </div>
</body>