有什么方法可以在通过.net将始终加密的列插入表中时使用dbCommand和AddInParameter?
.db。AddInParameter(dbCommand, "@SSN", DbType.string, SSN);
关于 .NET Framework 数据提供程序如何处理此问题 - 如果基础对象是 SqlParameter,则无需专门执行任何操作。
有关此的更多详细信息: 使用 .NET Framework 数据提供程序始终加密进行开发
.NET Framework Data Provider for SQL Server 自动检测 并加密以加密列为目标的参数。
我假设您使用的是企业库。查看 AddInParameter 方法 - 它在内部创建一个 DbParameter,SqlParamter 继承自 DbParameter。似乎相同的规则适用于您的情况。
话虽如此,您可能需要重新考虑使用企业库,以支持直接 ADO.NET,实体框架或像Dapper这样的微型ORM。据我所知,企业库不是一个活跃的项目/正在维护。
编辑
似乎您可以将 SqlParameter 传递给 dbCommand。
示例(未测试)
DatabaseProviderFactory factory = new DatabaseProviderFactory();
Database db = factory.CreateDefault();
var dbCommand = db.GetStoredProcCommand("spINSERT");
SqlParameter p = new SqlParameter("xxxxxx", "yyyyyy") {SqlDbType = SqlDbType.VarChar};
dbCommand.Parameters.Add(p);
db.ExecuteNonQuery(dbCommand);