这些日子感觉山外有山楼外楼,很多写法发觉能够改进自己能力。
<script language="javascript">
var arr =@Html.Raw(HttpContext.Current.Application["UAMDomainName"]);
var appCtx={};
for(var i=0;i<arr["Data"].length;i++)
{
//appCtx[arr["Data"][i]] = arr["Data"][i];
$.each(arr["Data"][i], function (key, value) {
appCtx[key] = value;
});
}
</script>
这种获得的必须是有状态的restful数据,必须在注入的时候用List<IDictionary<string,string>>泛型的对象外包消息状态返回。但是MVC1.1有更好的方法,被我们总监说了一顿,茅塞顿开。
[Service]
public class AppQuery
{
[Autowired]
public IAgencyService AgencyService { get; set; }
/// <summary>
/// 通过AppNmae获得UAM的APP
/// </summary>
/// <param name="vo"></param>
public List<Com.Centaline.TradeManagement.Entity.Vo.Workflow.DomainNameLst> getApp(getAppByAppNameParameter vo)
{
List<Com.Centaline.TradeManagement.Entity.Vo.Workflow.DomainNameLst> DomainNameLst = new List<Com.Centaline.TradeManagement.Entity.Vo.Workflow.DomainNameLst>();
try
{
DataResult<List<AppName>> viewmodel = new DataResult<List<AppName>>();
AppNameListVo result = AgencyService.GetInfo<AppNameListVo, getAppByAppNameParameter>(vo, 2, 14);
viewmodel.Result = result.content;
viewmodel.Message = result.message;
viewmodel.Code = result.code==null?0:1;
if (viewmodel.Message == "操作成功")
{
for (int i = 0; i < viewmodel.Result.Count; i++)
{
DomainNameLst.Add(new Com.Centaline.TradeManagement.Entity.Vo.Workflow.DomainNameLst(viewmodel.Result[i].appName, string.Format("{0}://{1}:{2}/{3}", viewmodel.Result[i].schemas, viewmodel.Result[i].host, viewmodel.Result[i].port, viewmodel.Result[i].appName)));
}
}
return DomainNameLst;
}
catch (Exception e)
{
throw (e);
}
}
}
然后在Global.ascx里面调用服务定位器模式来注入service:
getAppByAppNameParameter vo = new getAppByAppNameParameter();
AppQuery appquery = (AppQuery)ServiceLocatorFatory.ObjectContainer.GetService(typeof(AppQuery));
Application.Lock();
Application.Add("UAMDomainName", appquery.getApp(vo));
Application.UnLock();