gpt4 book ai didi

c# - ASP.NET 最干净的方法使跨应用程序的缓存无效

转载 作者:太空宇宙 更新时间:2023-11-03 23:44:23 26 4
gpt4 key购买 nike

我有两个 ASP.NET 应用程序在同一台服务器上运行并共享同一数据库。一种是使用 MVC 开发的前端,它缓存数据以避免数据库调用来检索相同的对象。另一个是后端,使用WebForms开发,用于管理CRUD操作。

我想在后端操作发生时使前端缓存失效。我不需要改进的机制...后端只会偶尔使用,并且可能会使所有缓存的对象无效。

我遇到过一些解决方案,但它们都不是很干净的解决方案...例如,在数据库设置表上放置一个标志,使用共享配置文件,从后台调用前端 Web 服务 -结束申请。每次调用前端页面时都需要应用每个解决方案,因此我需要尽可能减少资源消耗。

我不想使用 memcached 或 AppFabric 或类似的,因为我认为它们对我的基本需求来说太过分了。

非常感谢!

最佳答案

您可以执行一个使缓存无效的操作。你可以传递一个 secret token 来检查请求是否来自你的其他网络应用程序以确保安全。

所以它看起来像这样:

public ActionResult Invalidate(string key)
{
if (key == ConfigurationManager.AppSettings["ApplicationSecurityKey"])
{
_cacheService.Invalidate();
return Content("ok");
}
return null;
}

在两个项目的 web.config 文件中,您将拥有:

<appSettings>
<add key="ApplicationSecurityKey" value="SomeVerySecureValue" />
</appsettings>

您可以像这样从您的其他 Web 应用程序调用它:

WebClient client = new WebClient();               
client.QueryString.Add("key", ConfigurationManager.AppSettings["ApplicationSecurityKey"]);
string response = client.DownloadString(url)

关于c# - ASP.NET 最干净的方法使跨应用程序的缓存无效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27941637/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com