這些日子感覺山外有山樓外樓,很多寫法發覺能夠改進自己能力。
<script language="javascript">
var arr [email protected](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();