OpenAuth.Net/OpenAuth.WebApi/Areas/SSO/Controllers/LoginController.cs
2016-07-08 11:28:38 +08:00

122 lines
3.4 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using System;
using System.Web.Mvc;
using Newtonsoft.Json;
using OpenAuth.App.SSO;
using OpenAuth.WebApi.Areas.SSO.Models;
using OpenAuth.WebApi.Areas.SSO.Models.Services;
namespace OpenAuth.WebApi.Areas.SSO.Controllers
{
/// <summary>
/// 公钥AppKey
/// 私钥AppSecret
/// 会话Token
/// </summary>
public class LoginController : Controller
{
private readonly AppInfoService _appInfoService = new AppInfoService();
private readonly AppUserService _appUserService = new AppUserService();
private const string AppInfo = "AppInfo";
//默认登录界面
public ActionResult Index(string appKey = "", string username = "")
{
TempData[AppInfo] = _appInfoService.Get(appKey);
var viewModel = new PassportLoginRequest
{
AppKey = appKey,
UserName = username,
};
return View(viewModel);
}
//授权登录
[HttpPost]
public ActionResult Index(PassportLoginRequest model)
{
var result = Parse(model);
if (result.Success)
{
var redirectUrl = string.Format("{0}?token={1}&sessionusername={2}", result.ReturnUrl, result.Token, model.UserName);
//跳转默认回调页面
return Redirect(redirectUrl);
}
return View(model);
}
[HttpPost]
public string Check(PassportLoginRequest request)
{
return JsonConvert.SerializeObject(Parse(request));
}
[HttpPost]
public bool Logout(string token, string requestid)
{
try
{
new UserAuthSessionService().Remove(token);
return true;
}
catch (Exception)
{
return false;
}
}
private LoginResult Parse(PassportLoginRequest model)
{
//过滤字段无效字符
model.Trim();
var result = new LoginResult();
//获取应用信息
var appInfo = _appInfoService.Get(model.AppKey);
if (appInfo == null)
{
result.Success = false;
result.ErrorMsg = "应用不存在";
}
TempData[AppInfo] = appInfo;
//获取用户信息
var userInfo = _appUserService.Get(model.UserName);
if (userInfo == null)
{
result.Success = false;
result.ErrorMsg = "用户不存在";
}
//if (userInfo.UserPwd != model.Password.ToMd5())
//{
// //密码不正确
// return View(model);
//}
var currentSession = new UserAuthSession
{
UserName = model.UserName,
Token = Guid.NewGuid().ToString().ToMd5(),
InvalidTime = DateTime.Now.AddMinutes(10),
AppKey = model.AppKey,
CreateTime = DateTime.Now,
IpAddress = Request.UserHostAddress
};
//创建Session
new UserAuthSessionService().Create(currentSession);
result.Success = true;
result.ReturnUrl = appInfo.ReturnUrl;
result.Token = currentSession.Token;
return result;
}
}
}