我有一个简单的ASP.NET Web Form应用程序,具有身份 OWIN用于身份验证。这很好。
现在,我需要创建一个WebService(.ASMX(,以使我的用户通过服务对用户进行身份验证。因此该服务可以接受用户名 密码并验证它们。
这是为Android应用程序验证用户所必需的。
我不想使用其他任何身份验证,例如Google或Facebook .. Etc ...
也没有MVC。
任何人都可以把我指向解决方案。
Bellow是我的登录。ASPX页面的代码。我应该放在网站服务中。?
Android应用程序开发人员是另一个人。我只需要确保我的网站服务正常。
protected void SignIn(object sender, EventArgs e)
{
var userStore = new UserStore<IdentityUser>();
var userManager = new UserManager<IdentityUser>(userStore);
var user = userManager.Find(UserName.Text, Password.Text);
if (user != null)
{
var authenticationManager = HttpContext.Current.GetOwinContext().Authentication;
var userIdentity = userManager.CreateIdentity(user, DefaultAuthenticationTypes.ApplicationCookie);
authenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = false }, userIdentity);
string cs = ConfigurationManager.ConnectionStrings["DB_6"].ConnectionString;
using (SqlConnection conn = new SqlConnection(cs))
{
SqlCommand cmd = new SqlCommand("spGetUser", conn);
SqlDataAdapter Adpt = new SqlDataAdapter();
DataSet login = new DataSet();
try
{
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@PEmail", UserName.Text);
Adpt.SelectCommand = cmd;
Adpt.Fill(login);
foreach (DataRow dr in login.Tables[0].Rows)
{
string PFName = login.Tables[0].Rows[0]["PFName"].ToString();
string PLName = login.Tables[0].Rows[0]["PLName"].ToString();
string PType = login.Tables[0].Rows[0]["PType"].ToString();
int PersonID = int.Parse(login.Tables[0].Rows[0]["PersonID"].ToString());
using (SqlConnection con = new SqlConnection(cs))
{
SqlCommand cmd1 = new SqlCommand("spInsLoc", con);
cmd1.CommandType = CommandType.StoredProcedure;
cmd1.Parameters.Add("@PersonID", SqlDbType.Int).Value = PersonID;
cmd1.Parameters.Add("@OrgID", SqlDbType.Int).Value = 0;
cmd1.Parameters.Add("@Location", SqlDbType.NVarChar).Value = hdnLocation.Value;
cmd1.Parameters.Add("@strOwner", SqlDbType.VarChar).Value = UserName.Text;
cmd1.Parameters.Add("@dbTstamp", SqlDbType.DateTime2).Value = DateTime.Now;
con.Open();
cmd1.ExecuteNonQuery();
}
}
}
catch { }
finally { }
}
Response.Redirect("~/Login.aspx");
}
else
{
StatusText.Text = "Invalid username or password.";
LoginStatus.Visible = true;
}
}
protected void SignOut(object sender, EventArgs e)
{
var authenticationManager = HttpContext.Current.GetOwinContext().Authentication;
authenticationManager.SignOut();
Response.Redirect("~/Login.aspx");
}
您需要在Web服务中使用post&amp; get方法。
创建新的Android应用程序,并使用射击或本机Java库作为http req。
这是请求的示例代码;
URL url;
HttpURLConnection urlConnection = null;
try {
url = new URL("http://yoursite.com?name=foo?pass=foo");
urlConnection = (HttpURLConnection) url
.openConnection();
InputStream in = urlConnection.getInputStream();
InputStreamReader isw = new InputStreamReader(in);
int data = isw.read();
while (data != -1) {
char current = (char) data;
data = isw.read();
System.out.print(current);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
}
您的Web服务将响应请求。
ex: yoursite.com?name=foo?pass=foo
响应 ->是或false