token in sessione

This commit is contained in:
Marco Audiffredi 2023-09-22 15:03:08 +02:00
parent 804dea9d0c
commit e0e655f5a2
9 changed files with 157 additions and 36 deletions

View File

@ -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

View File

@ -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()

View File

@ -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();

View File

@ -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
View 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);
}
}
}

View File

@ -3,7 +3,5 @@
}
<div class="text-center">
<h1 class="display-4">Welcome</h1>
<h1 class="display-4">Welcome</h1>
</div>

View File

@ -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");}

View File

@ -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>

View 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">
&copy; 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>