在B/S开发中,涉及到获取系统基础资料的问题,因为是在不同平台下的开发,采用了WCF方式获取。

下面是一个调用通用权限管理系统(吉日嘎拉)基础信息资料的一个demo供参考

调用原理图:

web.configWCF配置参考

web.config 相关配置

  <system.serviceModel>
<client>
<endpoint address="http://192.168.1.199/PermissionService.asmx"
binding="basicHttpBinding" bindingConfiguration="PermissionServiceSoap"
contract="WebPermission.PermissionServiceSoap" name="PermissionServiceSoap">
</endpoint>
<endpoint address="net.tcp://192.168.1.199:9999/DotNet.Business/BaseItemDetailsService/" behaviorConfiguration="Internet" binding="netTcpBinding" bindingConfiguration="netTcpBindingSmiple" contract="DotNet.Business.IBaseItemDetailsService" name="DotNet.Business.BaseItemDetailsService">
<identity>
<dns value="192.168.1.199" />
</identity>
</endpoint>
<endpoint address="net.tcp://192.168.1.199:9999/DotNet.Business/BaseItemsService/" behaviorConfiguration="Internet" binding="netTcpBinding" bindingConfiguration="netTcpBindingSmiple" contract="DotNet.Business.IBaseItemsService" name="DotNet.Business.BaseItemsService">
<identity>
<dns value="192.168.1.199" />
</identity>
</endpoint>
</client>
<behaviors>
<endpointBehaviors>
<behavior name="Internet">
</behavior>
</endpointBehaviors>
</behaviors>
<bindings> <basicHttpBinding>
<binding name="PermissionServiceSoap" />
<binding name="basicHttpBindingSmiple" maxBufferPoolSize="2147483647" maxBufferSize="2147483647" maxReceivedMessageSize="2147483647">
<security mode="None">
<transport clientCredentialType="Windows" />
</security>
</binding>
</basicHttpBinding> <netTcpBinding>
<binding name="netTcpBindingSmiple" maxBufferSize="2147483647" maxBufferPoolSize="2147483647" maxReceivedMessageSize="2147483647">
<security mode="None">
<transport clientCredentialType="Windows" />
<message clientCredentialType="Windows" />
</security>
</binding>
</netTcpBinding> </bindings> </system.serviceModel>

注意:下面的userInfo是登录通用权限管理系统后的用户信息表,登录后需要设置对应的安全认证信息。

页面

        /// <summary>
/// 基本信息表表名
/// </summary>
protected string itemName = string.Empty;
/// <summary>
/// 输出的json内容
/// </summary>
protected string jsonStr = string.Empty;
protected void Page_Load(object sender, EventArgs e)
{
Response.ContentType = "application/json";
itemName = string.IsNullOrWhiteSpace(RequestString("itemName")) || string.Equals(RequestString("itemName"), "null", StringComparison.OrdinalIgnoreCase) ? string.Empty : RequestString("itemName").Trim();
if (!string.IsNullOrWhiteSpace(itemName) && !string.IsNullOrWhiteSpace(itemName))
{
using (DataTable dt = ItemsManager.GetItemsDB(userInfo, "ItemsClass"))
{
//过滤 显示或不显示 DeletionStateCode为0的字段显示,Enabled为1的字段
BaseBusinessLogic.SetFilter(dt, BaseItemDetailsEntity.FieldDeletionStateCode, "0");
BaseBusinessLogic.SetFilter(dt, BaseItemDetailsEntity.FieldEnabled, "1");
DataTable dtNew = new DataTable();
dtNew.Columns.Add("key", typeof(string));
dtNew.Columns.Add("value", typeof(string));
for (int i = 0; i < dt.Rows.Count; i++)
{
DataRow row = dtNew.NewRow();
row["key"] = dt.Rows[i]["ITEMNAME"];
row["value"] = dt.Rows[i]["ITEMVALUE"];
dtNew.Rows.Add(row);
}
jsonStr = DataTableHelper.DataTable2Json(dtNew);
}
}
else
{
jsonStr = "{\"list\":[{\"key\":\"出错了\",\"value\":\"取数据出错\",\"myFlag\":\"没有传入参数值\"}]}";
}
Response.Write(jsonStr);
Response.End();
}

 业务层

using System.Collections.Generic;
using System.Data;
using System.Web;
namespace TransferFees.BLL
{
using System;
using System.Web.Caching;
using DotNet.Business;
using DotNet.Utilities;
using TransferFees.DAL;
using TransferFees.Foundation;
/// <summary>
/// 获取基础信息表资料业务类
/// 以安全的WCF方式访问
/// 1,增加缓存功能
///
/// <author>
/// <name>songbiao</name>
/// <date>2014.03.18</date>
/// </author>
/// </summary>
/// </summary>
/// </summary>
public class ItemsManager
{
/// <summary>
/// 获得基础信息表资料
/// 通过安全的WCF服务方式调用
/// 传入的用户实体含有配置的加密信息
/// </summary>
/// <param name="userInfo">用户实体</param>
/// <param name="itemName">要查询的基础信息表的表名</param>
/// <returns></returns>
public static DataTable GetItemsDB(BaseUserInfo userInfo, string itemName, bool refreshFlag = false)
{
string key = "GetItemsDB";
if (refreshFlag)
{
HttpContext.Current.Cache.Remove(key);
}
if (HttpContext.Current.Cache[key] == null)
{
lock (userInfo)
{
if (HttpContext.Current.Cache[key] == null)
{
DataTable dtRes = ItemsServices.GetItemsDB(userInfo, itemName);
CacheItemRemovedCallback onRemoveCallback = new CacheItemRemovedCallback(CacheHelper.CacheItemRemovedCallback);
HttpContext.Current.Cache.Add(key, dtRes, null, DateTime.Now.AddMinutes(30.0), Cache.NoSlidingExpiration, CacheItemPriority.NotRemovable, onRemoveCallback);
}
}
}
return HttpContext.Current.Cache[key] as DataTable;
} /// <summary>
/// 获得基础信息表资料
/// 用户实体含有配置的加密信息
/// </summary>
/// <param name="userInfo">用户实体</param>
/// <param name="itemName">要查询的基础信息表的表名</param>
/// <returns></returns>
public static List<BaseItemDetailsEntity> GetItemsList(BaseUserInfo userInfo, string itemName, bool refreshFlag = false)
{
string key = "GetItemsList";
if (refreshFlag)
{
HttpContext.Current.Cache.Remove(key);
}
if (HttpContext.Current.Cache[key] == null)
{
lock (userInfo)
{
if (HttpContext.Current.Cache[key] == null)
{
List<BaseItemDetailsEntity> listRes = ItemsServices.GetItemsList(userInfo, itemName);
CacheItemRemovedCallback onRemoveCallback = new CacheItemRemovedCallback(CacheHelper.CacheItemRemovedCallback);
HttpContext.Current.Cache.Add(key, listRes, null, DateTime.Now.AddMinutes(30.0), Cache.NoSlidingExpiration, CacheItemPriority.NotRemovable, onRemoveCallback);
}
}
}
return HttpContext.Current.Cache[key] as List<BaseItemDetailsEntity>;
}
}
}

数据访问层

using System.Collections.Generic;
using System.Data;
using DotNet.Business;
using DotNet.Utilities; namespace TransferFees.DAL
{
/// <summary>
/// 获取基础信息表资料服务类
/// 以安全的WCF方式访问
///
/// <author>
/// <name>songbiao</name>
/// <date>2014.03.18</date>
/// </author>
/// </summary>
/// </summary>
/// </summary>
public class ItemsServices
{
/// <summary>
/// 获得基础信息表资料
/// 通过安全的WCF服务方式调用
/// 用户实体含有配置的加密信息
/// </summary>
/// <param name="userInfo">用户实体</param>
/// <param name="itemName">要查询的基础信息表的表名</param>
/// <returns></returns>
public static DataTable GetItemsDB(BaseUserInfo userInfo,string itemName)
{
DotNetService dotNetService = new DotNetService("DotNet.WCFClient");
return dotNetService.BaseItemDetailsService.GetDataTable(userInfo, itemName);
}
/// <summary>
/// 获得基础信息表资料
/// 用户实体含有配置的加密信息
/// </summary>
/// <param name="userInfo">用户实体</param>
/// <param name="itemName">要查询的基础信息表的表名</param>
/// <returns></returns>
public static List<BaseItemDetailsEntity> GetItemsList(BaseUserInfo userInfo, string itemName)
{
DotNetService dotNetService = new DotNetService("DotNet.WCFClient");
return dotNetService.BaseItemDetailsService.GetList(userInfo, "ItemsClass");
}
}
}

这段时间一直在基于吉日嘎拉的通用权限管理系统上做开发,真心感觉他真的是很强大,

他真的不仅仅是一套权限管理系统,底层涉及到的安全问题考虑的也非常全面

用上这套权限管理系统,我们只需关心业务就行了,时间对开发人员、对公司来说都非常重要,有一个好的选择我们一定要用上。

今后有机会会分享更多的应用,欢迎使用过这套系统的朋友一起交流。

以WCF安全认证方式调用通用权限管理系统获取基础信息资料的更多相关文章

  1. 通用权限管理系统接口文档V4.2 版本之消息接口介绍

    通用权限管理系统提供的消息接口可实现消息获取,消息发送,底层使用Redis对消息进行缓存,解决消息的并发请求对数据库的压力. 前端可以通过客户端轮询来获取最新消息,前端效果截图如下:

  2. 如何在通用权限管理系统中集成log4net日志功能

    开发人员都知道,在系统运行中要记录各种日志,自己写一个日志功能,无论是在效率还是功能扩展上来说都不是很好,目前大多用的是第三方的日志系统,其中一个非常有名,用的最多的就是log4net.下面是关于这个 ...

  3. 通用权限管理系统底层更换最新Oracle驱动的方法

    通用权限管理系统底层先前访问Oracle数据库时需要客户端安装驱动软件,如下图: 安装完毕还需要一番配置,系统再引用其dll, 现在我们使用了最新的dll 该dll是Oracle出的最新的版本. 通用 ...

  4. 使用 Shiro 设计基于用户、角色、权限的通用权限管理系统

    一.前言 在大型的信息管理系统中,经常涉及到权限管理系统 下面来个 demo,很多复杂的系统的设计都来自它 代码已经放到github上了,地址:https://github.com/larger5/s ...

  5. Net 通用权限管理系统源码 带数据库设计文档,部署说明文档

    Net 通用权限管理系统源码 带数据库设计文档,部署说明文档 包括数据库设计文档部署安装文档源码数据库文件 下载地址:http://www.mallhd.com/archives/1389

  6. 通用权限管理系统数据字典 V3.9 版本,欢迎开发个各种业务系统的朋友们,参考表结构

    C#.NET通用权限管理系统组件数据字典 导  航 ◇ (01) BaseItemDetails ◇ (02) BaseItems ◇ (03) BaseLog ◇ (04) BaseMessage ...

  7. 通用权限管理系统Ver2.0

    通用权限管理系统Ver2.0平台采用kendo+mvc4+Nhibernate技术实现,底层采用自定义ORM实现数据库底层代码,支持Oracle.SqlServer.mysql等常用数据库,界面采用k ...

  8. 通用权限管理系统之权限菜单zTree树的展示及移动的处理方法

    在通用权限管理系统中,有很多数据结构是有父子关系的,如组织机构,部门,权限菜单等,在展示的时候,大多数是通过zTree树的形式展现的,如下: 权限菜单展示 这种数据后台输出比较容易处理,参考如下获取某 ...

  9. 基于Extjs 4.2的通用权限管理系统,通用后台模板,EF+MVC+Extjs 4.2

    基于Extjs 4.2的通用权限管理系统,通用后台. 我们的宗旨:珍爱生命,拒绝重复!Don't Repeat Yourself!!! 本案例采用EntityFramework+MVC4.0+Extj ...

随机推荐

  1. Android应用性能优化笔记(java代码优化)

    Java代码优化  缓存结果:  如果计算代价过高,最好把过去的结果缓存起来. 伪代码如下: result=cache.get(n);        //输入参数n作为键 if(result==nul ...

  2. Windows Server 2003下ASP.NET无法识别IE11的解决方法【转】

    http://www.iefans.net/windows-server-2003-asp-net-ie11-shibie/ 由于IE11对User-Agent字符串进行了比较大的改动,所以导致很多通 ...

  3. RabbitMQ (二)工作队列 -摘自网络

    这篇中我们将会创建一个工作队列用来在工作者(consumer)间分发耗时任务.工作队列的主要任务是:避免立刻执行资源密集型任务,然后必须等待其完成.相反地,我们进行任务调度:我们把任务封装为消息发送给 ...

  4. Standalone Django scripts

    Standalone Django scripts DJANGO_SETTINGS_MODULE=foo.settings

  5. Getting Started with Entity Framework 6 Code First using MVC 5--Contoso 大学

    在本教程中使用的软件版本 Visual Studio 2013 年 4.5.NET 实体框架 (EntityFramework 6.1.0 NuGet 包) 6 Windows Azure SDK 2 ...

  6. JDBC学习笔记(10)——调用函数&存储过程

    如何使用JDBC调用存储在数据库中的函数或存储过程: * 1.通过COnnection对象的prepareCall()方法创建一个CallableStatement *    对象的实例,在使用Con ...

  7. ASP防注入

    因为在改进公司的一套ASP代码,所以考虑了一下防注入的问题. 参考了网上的几处代码,进行了修改和整合,都转换成小写再处理. 还考虑了script注入. 代码如下: 'Asp防注入代码 SQL_injd ...

  8. ASP获取json天气信息

    ASP代码(ASP获取页面源码方法,有编码.超时时间参数,处理了乱码.超时的问题): Function GetHttpPage(HttpUrl) Then GetHttpPage="$Fal ...

  9. 介绍50个 WordPress 动作挂钩

    WordPress 之所以能成为世界上最受欢迎的网页内容管理系统,原因就在于它的高度灵活性和可塑性,而这种灵活性和可塑性正是由“挂钩”(Hooks)简洁宜用的结构所决定的.可以说,没有过滤挂钩(Fil ...

  10. 解决mysql导入导出数据乱码问题

    最近在linux上面用mysqldump导出数据,放在windows系统中导入就会出现中文乱码,然后就会导致出现: Unknown MySQL server host和Can't connect to ...