token in sessione
This commit is contained in:
parent
804dea9d0c
commit
e0e655f5a2
@ -1,5 +1,8 @@
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Humanizer;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Newtonsoft.Json;
|
||||
using NuGet.Common;
|
||||
using System.Runtime.Intrinsics.Arm;
|
||||
using VirtualTask.Models;
|
||||
using X.PagedList;
|
||||
|
||||
@ -7,22 +10,30 @@ namespace VirtualTask.Controllers
|
||||
{
|
||||
public class AnagController : Controller
|
||||
{
|
||||
Uri baseAddress = new Uri("http://10.0.0.187:8000/api/Polo/anagraficheList?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJodHRwOi8vc2NoZW1hcy54bWxzb2FwLm9yZy93cy8yMDA1LzA1L2lkZW50aXR5L2NsYWltcy9uYW1lIjoiVEVTVCIsImp0aSI6IjA2MzA5MzlmLTBhZDgtNDhkMi04ZTI5LWI3Mjk3N2IyOWM1YiIsInRlbmFudCI6Ik1BUlJPIiwidGNjb2RpY2UiOiJaWlogICAgICAgICAgICAiLCJleHAiOjE3MDE3Njk0NTUsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6NjE5NTUiLCJhdWQiOiJodHRwOi8vbG9jYWxob3N0OjQyMDAifQ.CDt3wR6ube4zzNscVG9Qv6bzOnNF6A9-bIZxxjbKmKI");
|
||||
string apiUrl = string.Empty;
|
||||
string urlBase=string.Empty;
|
||||
string token=string.Empty;
|
||||
//Uri baseAddress = new Uri("http://10.0.0.187:8000/api/Polo/anagraficheList?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJodHRwOi8vc2NoZW1hcy54bWxzb2FwLm9yZy93cy8yMDA1LzA1L2lkZW50aXR5L2NsYWltcy9uYW1lIjoiVEVTVCIsImp0aSI6IjA2MzA5MzlmLTBhZDgtNDhkMi04ZTI5LWI3Mjk3N2IyOWM1YiIsInRlbmFudCI6Ik1BUlJPIiwidGNjb2RpY2UiOiJaWlogICAgICAgICAgICAiLCJleHAiOjE3MDE3Njk0NTUsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6NjE5NTUiLCJhdWQiOiJodHRwOi8vbG9jYWxob3N0OjQyMDAifQ.CDt3wR6ube4zzNscVG9Qv6bzOnNF6A9-bIZxxjbKmKI");
|
||||
//Uri baseAddress = new Uri("http://10.0.0.187:8000/api/Polo/anagraficheList?token=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJodHRwOi8vc2NoZW1hcy54bWxzb2FwLm9yZy93cy8yMDA1LzA1L2lkZW50aXR5L2NsYWltcy9uYW1lIjoiVEVTVCIsImp0aSI6IjA2MzA5MzlmLTBhZDgtNDhkMi04ZTI5LWI3Mjk3N2IyOWM1YiIsInRlbmFudCI6Ik1BUlJPIiwidGNjb2RpY2UiOiJaWlogICAgICAgICAgICAiLCJleHAiOjE3MDE3Njk0NTUsImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6NjE5NTUiLCJhdWQiOiJodHRwOi8vbG9jYWxob3N0OjQyMDAifQ.CDt3wR6ube4zzNscVG9Qv6bzOnNF6A9-bIZxxjbKmKI");
|
||||
HttpClient client;
|
||||
public AnagController()
|
||||
{
|
||||
client = new HttpClient();
|
||||
client.BaseAddress = baseAddress;
|
||||
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
|
||||
public IActionResult Index(string searchString, int? page = 1)
|
||||
{
|
||||
//string lastSearch=string.Empty;
|
||||
//lastSearch = (string)ViewData["CurrentFilter"];
|
||||
|
||||
SessionHelper helper = new SessionHelper(this);
|
||||
token = helper.GetStringValue("tok");
|
||||
if (string.IsNullOrEmpty(token))
|
||||
return RedirectToAction("Index", "Login");
|
||||
|
||||
apiUrl = helper.GetStringValue("apiUrl");
|
||||
urlBase = apiUrl+"anagraficheList";
|
||||
urlBase = urlBase + "?token=" + token;
|
||||
Uri baseAddress = new Uri(urlBase);
|
||||
client = new HttpClient();
|
||||
client.BaseAddress = baseAddress;
|
||||
|
||||
List<Anag> modelList = new List<Anag>();
|
||||
HttpResponseMessage response = client.GetAsync(baseAddress).Result;
|
||||
|
||||
@ -35,8 +46,6 @@ namespace VirtualTask.Controllers
|
||||
{
|
||||
modelList = modelList.Where(s => s.andescri.ToUpper().Contains(searchString.ToUpper())).ToList();
|
||||
|
||||
//if(lastSearch!= searchString)
|
||||
// page = 1;
|
||||
ViewData["CurrentFilter"] = searchString;
|
||||
}
|
||||
else
|
||||
|
||||
@ -1,4 +1,5 @@
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using NuGet.Common;
|
||||
using System.Diagnostics;
|
||||
using VirtualTask.Models;
|
||||
|
||||
@ -7,7 +8,7 @@ namespace VirtualTask.Controllers
|
||||
public class HomeController : Controller
|
||||
{
|
||||
private readonly ILogger<HomeController> _logger;
|
||||
|
||||
string token = string.Empty;
|
||||
public HomeController(ILogger<HomeController> logger)
|
||||
{
|
||||
_logger = logger;
|
||||
@ -15,18 +16,17 @@ namespace VirtualTask.Controllers
|
||||
|
||||
public IActionResult Index()
|
||||
{
|
||||
string t = HttpContext.Session.GetString("tok");
|
||||
if (!string.IsNullOrEmpty(t))
|
||||
SessionHelper helper = new SessionHelper(this);
|
||||
token = helper.GetStringValue("tok");
|
||||
if (string.IsNullOrEmpty(token))
|
||||
{
|
||||
ViewBag.Token = t;
|
||||
return RedirectToAction("Index", "Login");
|
||||
}
|
||||
else
|
||||
{
|
||||
ViewBag.Token = token;
|
||||
return View();
|
||||
}
|
||||
else
|
||||
{
|
||||
ViewBag.Token = string.Empty;
|
||||
return RedirectToAction("Error", "Home");
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
public IActionResult Privacy()
|
||||
|
||||
@ -8,13 +8,14 @@ namespace VirtualTask.Controllers
|
||||
public class LoginController : Controller
|
||||
{
|
||||
|
||||
|
||||
Uri baseAddress = new Uri("http://10.0.0.187:8000/api/Polo/loginTechnical");
|
||||
string apiUrl=string.Empty;
|
||||
HttpClient client;
|
||||
SessionHelper helper;
|
||||
public LoginController()
|
||||
{
|
||||
apiUrl = "http://10.0.0.187:8000/api/Polo/";
|
||||
client = new HttpClient();
|
||||
client.BaseAddress = baseAddress;
|
||||
helper = new SessionHelper(this);
|
||||
}
|
||||
public IActionResult Index()
|
||||
{
|
||||
@ -28,6 +29,11 @@ namespace VirtualTask.Controllers
|
||||
[HttpPost]
|
||||
public IActionResult Login(Login model)
|
||||
{
|
||||
string url = apiUrl + "loginTechnical";
|
||||
Uri baseAddress = new Uri(url);
|
||||
client.BaseAddress = baseAddress;
|
||||
|
||||
//SessionHelper helper = new SessionHelper(this);
|
||||
LoginOut loginOut = new LoginOut();
|
||||
string data = JsonConvert.SerializeObject(model);
|
||||
StringContent content = new StringContent(data, Encoding.UTF8, "application/json");
|
||||
@ -39,9 +45,10 @@ namespace VirtualTask.Controllers
|
||||
|
||||
string risultato = response.Content.ReadAsStringAsync().Result;
|
||||
loginOut = JsonConvert.DeserializeObject<LoginOut>(risultato);
|
||||
HttpContext.Session.SetString("tok", loginOut.Tok);
|
||||
|
||||
|
||||
//HttpContext.Session.SetString("tok", loginOut.Tok);
|
||||
//ViewBag.Token = loginOut.Tok;
|
||||
helper.SetStringValue("tok", loginOut.Tok);
|
||||
helper.SetStringValue("apiUrl", apiUrl);
|
||||
return RedirectToAction("Index","Home");
|
||||
}
|
||||
return View();
|
||||
|
||||
@ -7,7 +7,7 @@ builder.Services.AddDistributedMemoryCache();
|
||||
|
||||
builder.Services.AddSession(options =>
|
||||
{
|
||||
options.IdleTimeout = TimeSpan.FromSeconds(10);
|
||||
|
||||
options.Cookie.HttpOnly = true;
|
||||
options.Cookie.IsEssential = true;
|
||||
});
|
||||
|
||||
60
SessionHelper.cs
Normal file
60
SessionHelper.cs
Normal file
@ -0,0 +1,60 @@
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using System.Text;
|
||||
|
||||
namespace VirtualTask
|
||||
{
|
||||
public class SessionHelper
|
||||
{
|
||||
private Controller _controller;
|
||||
|
||||
public SessionHelper(Controller controller)
|
||||
{
|
||||
_controller = controller;
|
||||
}
|
||||
|
||||
public string GetStringValue(string key)
|
||||
{
|
||||
return _controller.HttpContext.Session.GetString(key);
|
||||
}
|
||||
|
||||
public void SetStringValue(string key, string value)
|
||||
{
|
||||
|
||||
_controller.HttpContext.Session.SetString(key, value);
|
||||
}
|
||||
|
||||
public int? GetInt32Value(string key)
|
||||
{
|
||||
return _controller.HttpContext.Session.GetInt32(key);
|
||||
}
|
||||
|
||||
public void SetInt32Value(string key, int value)
|
||||
{
|
||||
|
||||
_controller.HttpContext.Session.SetInt32(key, value);
|
||||
}
|
||||
|
||||
public Byte[] GetBytesValue(string key)
|
||||
{
|
||||
return _controller.HttpContext.Session.Get(key);
|
||||
}
|
||||
|
||||
public void SetBytesValue(string key, Byte[] value)
|
||||
{
|
||||
|
||||
_controller.HttpContext.Session.Set(key, value);
|
||||
}
|
||||
|
||||
public void SetStringAsBytesValue(string key, string value)
|
||||
{
|
||||
var bytes = Encoding.UTF8.GetBytes(value);
|
||||
_controller.HttpContext.Session.Set(key, bytes);
|
||||
}
|
||||
|
||||
public string GetStringFromBytesValue(string key)
|
||||
{
|
||||
var bytes = _controller.HttpContext.Session.Get(key);
|
||||
return Encoding.UTF8.GetString(bytes);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -3,7 +3,5 @@
|
||||
}
|
||||
|
||||
<div class="text-center">
|
||||
<h1 class="display-4">Welcome</h1>
|
||||
|
||||
|
||||
<h1 class="display-4">Welcome</h1>
|
||||
</div>
|
||||
|
||||
@ -2,7 +2,7 @@
|
||||
|
||||
@{
|
||||
ViewData["Title"] = "Login";
|
||||
|
||||
Layout = "~/Views/Shared/_LayoutLogin.cshtml";
|
||||
}
|
||||
|
||||
<h1>Login</h1>
|
||||
@ -35,7 +35,9 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<script src="~/lib/jquery/dist/jquery.min.js"></script>
|
||||
<script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
<script src="~/js/site.js" asp-append-version="true"></script>
|
||||
|
||||
@section Scripts {
|
||||
@{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
|
||||
|
||||
@ -28,6 +28,9 @@
|
||||
<li class="nav-item">
|
||||
<a class="nav-link text-dark" asp-area="" asp-controller="Tecnici" asp-action="Index">TECNICI</a>
|
||||
</li>
|
||||
<li class="nav-item">
|
||||
<a class="nav-link text-dark" asp-area="" asp-controller="Anag" asp-action="Index">ANAGRAFICHE</a>
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
42
Views/Shared/_LayoutLogin.cshtml
Normal file
42
Views/Shared/_LayoutLogin.cshtml
Normal file
@ -0,0 +1,42 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<title>@ViewData["Title"] - VirtualTask</title>
|
||||
<link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.min.css" />
|
||||
<link rel="stylesheet" href="~/css/site.css" asp-append-version="true" />
|
||||
<link rel="stylesheet" href="~/VirtualTask.styles.css" asp-append-version="true" />
|
||||
</head>
|
||||
<body>
|
||||
<header>
|
||||
<nav class="navbar navbar-expand-sm navbar-toggleable-sm navbar-light bg-white border-bottom box-shadow mb-3">
|
||||
<div class="container-fluid">
|
||||
<a class="navbar-brand" asp-area="" asp-controller="" asp-action="" disabled>VirtualTask</a>
|
||||
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target=".navbar-collapse" aria-controls="navbarSupportedContent"
|
||||
aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="navbar-collapse collapse d-sm-inline-flex justify-content-between">
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
</header>
|
||||
<div class="container">
|
||||
<main role="main" class="pb-3">
|
||||
@RenderBody()
|
||||
</main>
|
||||
</div>
|
||||
|
||||
<footer class="border-top footer text-muted">
|
||||
<div class="container">
|
||||
© 2023 - VirtualTask @ViewBag.Token
|
||||
</div>
|
||||
</footer>
|
||||
<script src="~/lib/jquery/dist/jquery.min.js"></script>
|
||||
<script src="~/lib/bootstrap/dist/js/bootstrap.bundle.min.js"></script>
|
||||
<script src="~/js/site.js" asp-append-version="true"></script>
|
||||
@await RenderSectionAsync("Scripts", required: false)
|
||||
</body>
|
||||
</html>
|
||||
Loading…
Reference in New Issue
Block a user