解决一蛋痛的WCF-REST配置问题:未找到注册基址方案
作者:V君 发布于:2017-3-14 20:12 Tuesday 分类:挖坑经验
状况:
访问时出现以下错误
找不到具有绑定 WebHttpBinding 的终结点的与方案 http 匹配的基址。注册的基址方案是[]。
注意, 注册的基址方案是空的, 和遍地都是的 “注册的基址方案是[http]”不同
TL;DR:
在 web.config 配置基址前缀就能解决该问题.
<serviceHostingEnvironment>
<baseAddressPrefixFilters>
<add prefix="http://localhost" />
</baseAddressPrefixFilters>
</serviceHostingEnvironment>
扯扯:
扯你妹不想扯了, 花了好大劲都解决不了.
结果 ServerAdmin 告诉咱们想起以前的项目遇到类似的情况时,负责人的做法...
so.解决不了配置问题的码农不是好运维? ( ゚∀。)
标签: 软件开发 C# ASP.NET MVC WCF REST 运行时错误
使用非公开辅助类HttpValueCollection轻松生成QueryString
作者:V君 发布于:2016-11-7 18:19 Monday 分类:挖坑经验
TL;DR
var kvp = HttpUtility.ParseQueryString("");
kvp["a"]="bc";
kvp["b"]="cd";
kvp["c"]="草";
var queryString=kvp.ToString(); //queryString结果为"a=bc&b=cd&c=%u8349"
注意:由于ToString会自动把内容做Url编码,某些服务接口需要计算数字签名可能会遇到问题,
这种情况还是只能自己拼字符串... 比如某德的接口 见下更新。
听我扯扯:
在做服务端调用远程Web接口时需要组装QueryString请求参数,
依稀记得在Web项目里用的QueryString是个NameValueCollection, 并能ToString还原
然而自己创建实例丢值进去却没得到理想的结果,
咕狗到爆栈得到答案:原来Web项目里的是M$重写过的内部类:HttpValueCollection
反编译发现确实如此, 然而要怎么用呢, 首先想到是反射再实例化,
这种做法略Hack,指不出哪天或哪个平台就来个空指针给你.
继续咕狗爆栈, 得出这么贱的用法, 塞他个空字符串让它吐出实例, 太棒了!
快来解决问题的帖子一起点赞吧!
更新:
可能由于历史包袱原因,%u编码似乎只能在IE使用,需要在AppSetting配置项里
加一条名称为“aspnet:DontUsePercentUUrlEncoding”值为“true”的配置项
解决ASP.NET Boilerplate与EntityFramework反复出现无用更新的现象[Update]
作者:V君 发布于:2016-10-23 15:49 Sunday 分类:挖坑经验
TL;DR
重写SaveChanges和SaveChangesAsync ,
在base实现调用之前增加以下代码,去除对前三个字段的无用更新的操作.
private static readonly HashSet<string> IgnoreCheckUpdateFields = new HashSet<string>
{
nameof(IAudited.CreationTime),
nameof(IAudited.LastModificationTime),
nameof(IAudited.LastModifierUserId),
nameof(Entity.Id),
};
private void BlockNeedLessUpdate()
{
//LEVEL 1: always CreationTime
var allModified = ChangeTracker
.Entries<ICreationAudited>()
.Where(p => p.State == EntityState.Modified);
foreach (var item in allModified)
item.Property(nameof(ICreationAudited.CreationTime))
.IsModified = false;
//LEVEL 2: only LastModificationTime LastModifierUserId
var allModified2 = ChangeTracker
.Entries<IAudited>()
.Where(p => p.State == EntityState.Modified);
foreach (var item in allModified2)
{
var changed = item.CurrentValues.PropertyNames
.Any(p => !IgnoreCheckUpdateFields.Contains(p)
&& false == item.CurrentValues[p]?.Equals(item.OriginalValues[p]));
if (changed) continue;
item.Property(nameof(IAudited.LastModificationTime)).IsModified = false;
item.Property(nameof(IAudited.LastModifierUserId)).IsModified = false;
}
}
听我扯扯:
由于ASP.NET Boilerplate首次启动/登录时很慢, 于是将EF生成的SQL语句打到调试输出.
发现大量的创建时间被更新的现象.
深入调查发现可能是因为 CreationAuditedEntity 在构造时初始化成 Clock.Now
然后EF从数据库读出值再次绑定,
造成 CreationTime 的 setter 被多次调用导致变更追踪机制懵逼.
粗暴地把所有对 CreationTime 的更新操作屏蔽就好了.
不知道是不是错觉, 这么做了之后发现调试启动速度快了70%呀.
ps. 或许 EF 的变更追踪没有 dbml 那么完善,它只监视赋值行为.然而 dbml 还检查了值变化.
Update:
随着继续调试又发现Tenant的LastModificationTime和LastModifierUserId被更新
然而并没更新到别的字段, 明显这样的更新动作是无用的.
进一步调试看起来EF只是简单的比较了两个装了箱的值, 然而在SQL层面又做了值重复过滤
导致这种尴尬现象.
解决ASP.NET Boilerplate连接MS SQL报Filter name MustHaveTenant not found
作者:V君 发布于:2016-10-23 15:20 Sunday 分类:挖坑经验
TL;DR
重写 OnModelCreating 要调用base实现. 加上调用base实现需要重建数据库.
听我扯扯:
受够MySQL提供程序的bug之后, 换MS SQL看看会不会好点.
直接在 DbContext 和迁移剔除所有 MySQL 的 Attribute
再去Web.Config把所有My配置去掉.连接字符串改到MS SQL.
编译然后生成数据库报错了. 提示 ON DELETE NO ACTION
咕狗到爆栈帖子说是实体关系配置问题. 重写了 OnModelCreating 方法.
然后, 尽管数据库生成出来了.
然而运行起来就爆炸鸟:Filter name MustHaveTenant not found....
各种问, 各种咕狗. 然后找到了ABP作者的回帖最终完美解决问题, 顺利地跑起来!
接下来看看EF-LINQ提供程序做复杂投影有没有MySQL的问题吧!
OCR 识别老验证码,老算式验证码,集装箱号 C#/JavaScript&HTML5
作者:V君 发布于:2016-9-10 3:25 Saturday 分类:挖坑经验
最近 这些天 在负责集装箱拖运相关的项目,
需要从某些行业平台上取得集装箱信息.
还要在手机网页识别集装箱号.
标签: 软件开发 javascript C# 图像处理 OCR
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)