- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是密码学新手。我读到对称和非对称算法分别使用一个和两个加密 key 。并且这些 key 必须存放在安全的地方。但是当我在网上搜索有关如何在 ASP.NET 中进行加密的教程时,我发现了一些奇怪的东西!例如this tutorial 。
加密或解密数据时没有存储或提供公钥或私钥!我不明白。
我遇到的另一个问题是,到目前为止我找到的所有教程都只是代码,没有任何关于这些代码是什么以及为什么使用的解释。我很感谢建议的任何好的教程。
最佳答案
来自RSACryptoServiceProvider Constructor :
If no default key is found, a new key is created.
This constructor creates an Exchange key pair suitable to encrypt session keys so that they can be safely stored and exchanged with other users. The generated key corresponds to a key generated using the AT_KEYEXCHANGE value used in the unmanaged Microsoft Cryptographic API (CAPI).
因此,如果找不到已经创建的 key 对,它只是生成一个新的 key 对;除了基于 session 的数据之外,您不应该使用它。
一点背景知识(我假设您使用 Windows),非对称 key 对与证书相关联。您可以使用这些证书来信任非对称 key 。每个证书都可以由证书颁发机构(颁发非对称 key 的机构)进行签名,如果您信任证书颁发机构,那么您就信任属于该机构签名的证书的非对称 key 。所有这些证书都存储在您的“证书存储”中,也称为“ key 存储”(Java)、“ key 环”(Mac)。
您可以通过执行开始 > 运行 > certmgr.msc
来查看您的证书。您的证书位于个人 > 证书下。如果您打开一个,然后转到“证书路径”选项卡,您将看到直至证书颁发机构的证书链。如果在您的受信任的根证书颁发机构 > 证书
存储中找到属于证书颁发机构的“根”证书,则该证书被视为有效且受信任。
如果您想为用户加密某些内容,您应该进入他的证书存储区,并提取他的加密证书。为此,您应该打开“当前用户” key 存储,并遍历其中的所有证书,并挑选出 key 用途为“ key 加密”的证书,如果有多个,则询问用户是哪一个他想使用。
如果您想使用服务帐户加密某些内容(例如,如果您是 Web 服务器),您应该使用“本地计算机” key 存储中找到的证书,并且仅授予您的服务帐户对关联私钥的读取权限与您要使用的证书。
这可以使用 X509Store Class 来完成,例如:
X509Store certificateStore = new X509Store("MY", StoreLocation.CurrentUser);
X509Certificate2Collection allCertificates = certificateStore.Certificates;
//Iterate through all certificates
“MY”代表个人证书,其余可查here 。 CurrentUser代表用户 key ,另一个选项是LocalMachine。
获得要使用的证书后,您应该结合对称 key 使用公钥进行加密,使用私钥进行解密。因此,如果您有大量想要加密的数据,您要做的是:
解密时你应该:
我有一堆代码示例可以完成此任务,如果您想看一下,请告诉我您需要哪一部分的帮助。
这可能有点令人困惑,所以请让我知道您想要澄清的内容。
关于asp.net - 加密 key 存储在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10851509/
我试图对 ASP.Net MVC 有一个高层次的理解,我开始意识到它看起来很像原始的 ASP 脚本。过去,我们将“模型”/业务逻辑代码组织到 VBScript 类或 VB COM 组件中。 当然,现在
我已经搜索了一段时间,但似乎找不到答案。 我想在我的旋转木马中显示一个计数器,左边是当前项目(工作),左边是项目总数。 我的代码:
. 最佳答案 Scott Gu 称这些为代码块。这就是我的看法。 http://weblogs.asp.net/scottgu/archive/2010/04/06/new-lt-gt-syntax
我有一个使用 Visual Studio 2010/.net 4/VB 制作的网站。 我真的很喜欢我发现的 FAQ 系统的布局,因为它很简单,但它是经典的 asp。所以,显然,我不能包括我的母版页布局
好吧,对于你们许多人来说,这个问题可能有一个非常明显的答案,但它让我难住了。 我有一个 asp.net Web 表单,上面有两个控件(嗯,不止这两个,但我们将重点关注这些) - 第一个是 asp:dr
当我将 ASP.NET 复选框控件设置为 asp.net 更新面板的异步回发触发器时,EventName 属性是什么? 最佳答案 我相信它是 CheckedChanged。 关于asp.net - a
我有一个用经典 asp 编写的(巨大的)网站。现在我必须切换到 vb.net (razor)。有没有办法将这两个结合起来直到切换完成? 有没有办法让应用程序与经典的 asp 和 vb.net 一起工作
I am creating a products page, where the user selects an option in a radiobuttonlist for example, an
我最近将一个经典的 ASP 应用程序转换为 ASP.NET 3.5,但我觉得我的经典 ASP 版本要快一些(我不知道可能买家会后悔)。 所以你们能帮我解决这个问题吗,让我知道哪个更快,asp、asp.
从本周开始,我被要求开始学习如何使用 ASP 开发网站。我通过 XNA 对 C# 有一定的经验,所以这部分对我来说并不是什么麻烦。 我一直在关注Music Store Tutorial这需要我设置一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我想将一些表单变量发布到经典 ASP 页面中。我不想改变经典的 ASP 页面,因为需要完成大量的工作,以及消耗它们的页面数量。 经典的 ASP 页面需要将表单变量 Username 和 Userpas
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
在某种程度上,这可能是一个异端问题。我们有一个大型站点,其中许多页面仍在ASP中。通常,并没有真正动态的,而是包括(通过SSI或Server.Execute)定期重新生成的HTML块。看起来好像是一个
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我有一个遗留的 ASP 应用程序——在不久的某个时候——需要迁移到 ASP.Net 2.0(以与也在 2.0 中的其他应用程序兼容)。 对于这类事情是否有最佳实践,即作为第一步将当前 html、vbs
我目前在一家公司工作,该公司使用 ASP.NET Webforms 和旧 ASP 页面的组合进行 Web 开发。这对于他们当前的项目来说效果很好,但我想说服/建议他们切换到 ASP.NET MVC,因
我有一个经典的 asp 应用程序。我想将该页面的竞赛表格发布到 Asp.Net 表格。原因是我想在进入数据库之前使用我在 Asp.Net 页面中内置的大量逻辑进行验证,而我对 asp 不太了解。更不用
我知道在 ASP.NET MVC 中,您可以拥有移动 View 并执行类似 Index.mobile.cshtml 的操作。和 _Layout.mobile.cshtml并且服务器知道将这些 View
我需要从一些服务器端 c#.net 代码中调用经典 asp 页面上的 VBscript 函数 - 有谁知道一种干净的方法来做到这一点?在 .net 中重写函数不是一种选择。 我会再解释一下这个问题..
我是一名优秀的程序员,十分优秀!