草庐IT

c# - 休眠 + QueryOver : filter with Where ignoring sensitive

我正在尝试使用QueryOver在nHibernate中构建一个简单的查询,但我希望它将所有内容转换为小写或忽略敏感信息:Domain.UserUser=Session.QueryOver().Where(x=>x.Login=="username").SingleOrDefault();我怎样才能做到这一点?更新:有人建议问题可能出在数据库的集合上,但我从来没有遇到过任何问题,这个脚本有效:Domain.UserUser=Session.CreateCriteria().Add(Expression.Eq("Login","username")).UniqueResult();

c# - 事件目录 : Retrieve User information

我有一个Web应用程序正在使用我们的ActiveDirectory针对Windows身份验证运行。我有一个新要求,需要从ActiveDirectory条目中提取一些个人信息。访问此信息的最简单方法是什么? 最佳答案 直接通过DirectoryEntry访问用户似乎是最直接的方法。以下是我从我的第一个AD相关项目中学到的一些与AD相关的花絮:在URI中,以小写形式写入LDAP。否则你会得到一个神秘的错误。我在这个令人沮丧的问题上花了一天多的时间......要清除单值属性,请将其设置为空字符串,而不是null。Null会导致异常。要清除

c# - 如何模拟采用动态对象的方法调用

假设我有以下内容:publicinterfaceISession{TGet(dynamicfilter);}}我有以下要测试的代码:varuser1=session.Get(new{Name="test1"});varuser2=session.Get(new{Name="test2"});我将如何模拟这个调用?使用最小起订量,我厌倦了这样做:varsessionMock=newMock();sessionMock.Setup(x=>x.Get(new{Name="test1")).Returns(newUser{Id=1});sessionMock.Setup(x=>x.Get(ne

c# - 可以将条件编译符号添加到 csproj.user 文件吗?

我正在VS2013中使用C#XamariniOS项目。我想添加一个条件编译符号而不影响任何其他人或不必进入配置管理器并说复制调试(主要是为了如果有人修改调试我不会错过更改)。我读过一些帖子说尝试将类似的内容添加到csproj.user文件中......$(DefineConstants);__MY_NEW_SYMBOL__...但这只会删除项目的所有其他符号。有没有办法修改csproj.user文件来实现这一点? 最佳答案 我发现这是一个非常古老的问题。我不确定是否有人真的在使用VS2013,但它在VS2017中工作,就像它在问题中

c# - User.IsInRole() 在角色分配后不工作,但在重新登录后工作

在ASP.NETMVC5应用程序中,我使用Unity容器创建OWIN/Identity对象并解析所有依赖项。问题是当我注册为新用户并给他分配这样的角色时userManager.AddToRole(user.Id,"NewUser");...awaituserManager.UpdateAsync(user);它实际上在AspNetUserRoles表中创建了一条记录,但在那之后如果我用User.IsInRole("NewUser")检查他的角色我得到的是假的,除非我注销然后重新登录,否则它是真的。我猜问题可能出在Unity上下文中的身份对象(UserManager、RoleManage

c# - 有什么办法可以规避 "Dialogs must be user-initiated"异常?

我的应用有一个“打开文件”按钮。在启动OpenFileDialog之前,它会询问用户是否要保存当前文件,如果需要,它会启动SaveFileDialog。然后启动OpenFileDialog。非常标准的东西。我的问题是silverlight然后将OpenFileDialog.ShowDialog()方法视为不是用户启动的,并且我得到了一个SecurityException。是否有任何已知的合理方法来避免此异常?这肯定是一个非常标准的场景?应用在浏览器中。欢迎任何想法编辑:抱歉,不允许发布实际代码:(虽然逻辑非常简单:在伪代码中,“OpenFile”按钮按下事件调用如下方法:*启动一条新的

c# - 如何通过 ConfigurationManager 写入 User.Config 文件?

我正在尝试使用ConfigurationManager将用户设置保存到配置文件中。我只想将这些设置限定为用户,因为在没有管理员权限的情况下无法在Vista/Win7上保存应用程序更改。这似乎让我得到了用户的配置,它似乎保存在Win7中([Drive]:\Users\[Username]\AppData\Local\[ApplicationName]\[AssemblyName][hash]\[Version\)Configurationconfig=ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.PerU

c# - 有没有像 "user-defined encoding fallback"这样的东西

当使用ASCII编码并将字符串编码为字节时,ö之类的字符将生成?。Encodingencoding=Encoding.GetEncoding("us-ascii");//orEncodingencoding=Encoding.ASCI;data=encoding.GetBytes(s);我正在寻找一种方法来用不同的字符替换这些字符,而不仅仅是问号。示例:ä->aeö->oeü->ueß->ss如果无法用多个字符替换一个字符,如果我能用一个字符替换它们,我会接受(ö->o)现在有几种EncoderFallback的实现,但是我不明白它们是如何工作的。一个快速而肮脏的解决方案是在将字符串提

c# - EF4 在不先获取实体的情况下更新实体

如何更新一个实体而不必调用它来选择它。如果我为实体提供key,它是否应该不知道在对ObjectContext调用SaveChanges()后进行更新。我目前这样做:varuser=context.Users.Single(u=>u.Id==2);user.Username="user.name";user.Name="ABC123";context.SaveChanges();这行得通,但会强制选择。因为我知道Id,为什么我不能做这样的事情:varuser=newUser();user.Id=2;user.Username="user.name";user.Name="ABC123";

c# - Entity Framework 不会在 SQL Express (MDF) 中保留数据

我正在使用EntityFramework开发应用程序并将数据存储在.mdf数据库中。我的代码可以读取数据,显然它也可以保存,但只是表面上。它没有错误,当程序运行时它就像数据已保存一样,例如我可以保存一个对象,处理上下文,创建一个新对象,然后当我搜索我的对象时它就在那里!但是当我查询数据库以查看存储的数据时,那里什么也没有。如果我关闭应用程序并再次运行它,所有数据都将消失。这是我为测试而编写的示例代码:using(DatabaseEntitiese=newDatabaseEntities()){for(inti=0;ius=e.User.Where(x=>x.ID();foreach(U