通用权限管理系统源码
‘壹’ 求一份简单的ssm(springmvc+mabatis)的java权限管理源码,学习用
http://www.sojson.com/shiro
ShiroDemo环境准备,建议使用0.2版本,这样你会遇到较少问题。
开发工具:Eclipse、MyEclipse、Idea等等。
依赖第三方:Mysql5.0以上、Redis。
需要的配置:jdbc.properties中配置Mysql的信息、spring-cache.xml配置Redis配置,
如果是默认配置,就不用换,RedisWindows安装:http://www.sojson.com/blog/110.html。
注意:0.1版本访问不要带项目路径访问。比如用:http://localhost:8080访问,别带设置带项目名称,如:http://localhost:8080/shiro.demo/这样是不对的。。也就是要把项目部署到Root下,也就是根目录下。0.2版本已经解决该问题了。
‘贰’ 如何在通用权限管理系统中集成log4net日志功能
首先在官网下载最新源码,目前的源码可用VS2010打开。
源码中已经实现了可以日志输出到MSSQL的功能,但我的项目目前使用的都是Oracle数据库,源码中是没有实现的,需要自己实现一下:
public class OracleAppender : BufferingAppenderSkeleton
{
// Fields
private static readonly Type declaringType = typeof(AdoNetAppender);
private string m_commandText;
private CommandType m_commandType = CommandType.Text;
private string m_connectionString;
private string m_connectionType;
private OracleCommand m_dbCommand;
private OracleConnection m_dbConnection;
protected ArrayList m_parameters = new ArrayList();
private bool m_reconnectOnError = false;
private SecurityContext m_securityContext;
protected bool m_usePreparedCommand;
private bool m_useTransactions = true;
// Methods
public override void ActivateOptions()
{
base.ActivateOptions();
this.m_usePreparedCommand = (this.m_commandText != null) && (this.m_commandText.Length > 0);
if (this.m_securityContext == null)
{
this.m_securityContext = SecurityContextProvider.DefaultProvider.CreateSecurityContext(this);
}
this.InitializeDatabaseConnection();
this.InitializeDatabaseCommand();
}
public void AddParameter(OracleAppenderParameter parameter)
{
this.m_parameters.Add(parameter);
}
protected virtual string GetLogStatement(LoggingEvent logEvent)
{
if (this.Layout == null)
{
this.ErrorHandler.Error("ADOAppender: No Layout specified.");
return "";
}
StringWriter writer = new StringWriter(CultureInfo.InvariantCulture);
this.Layout.Format(writer, logEvent);
return writer.ToString();
}
private void InitializeDatabaseCommand()
{
if ((this.m_dbConnection != null) && this.m_usePreparedCommand)
{
try
{
this.m_dbCommand = this.m_dbConnection.CreateCommand();
this.m_dbCommand.CommandText = this.m_commandText;
this.m_dbCommand.CommandType = this.m_commandType;
}
catch (Exception exception)
{
this.ErrorHandler.Error("Could not create database command [" + this.m_commandText + "]", exception);
if (this.m_dbCommand != null)
{
try
{
this.m_dbCommand.Dispose();
}
catch
{
}
this.m_dbCommand = null;
}
}
if (this.m_dbCommand != null)
{
try
{
foreach (OracleAppenderParameter parameter in this.m_parameters)
{
try
{
parameter.Prepare(this.m_dbCommand);
}
catch (Exception exception2)
{
this.ErrorHandler.Error("Could not add database command parameter [" + parameter.ParameterName + "]", exception2);
throw;
}
}
}
catch
{
try
{
this.m_dbCommand.Dispose();
}
catch
{
}
this.m_dbCommand = null;
}
}
if (this.m_dbCommand != null)
{
try
{
this.m_dbCommand.Prepare();
}
catch (Exception exception3)
{
this.ErrorHandler.Error("Could not prepare database command [" + this.m_commandText + "]", exception3);
try
{
this.m_dbCommand.Dispose();
}
catch
{
}
this.m_dbCommand = null;
}
}
}
}
private void InitializeDatabaseConnection()
{
try
{
this.m_dbConnection = new OracleConnection();
this.m_dbConnection.ConnectionString = this.m_connectionString;
using (this.SecurityContext.Impersonate(this))
{
this.m_dbConnection.Open();
}
}
catch (Exception exception)
{
this.ErrorHandler.Error("Could not open database connection [" + this.m_connectionString + "]", exception);
this.m_dbConnection = null;
}
}
protected override void OnClose()
{
base.OnClose();
if (this.m_dbCommand != null)
{
this.m_dbCommand.Dispose();
this.m_dbCommand = null;
}
if (this.m_dbConnection != null)
{
this.m_dbConnection.Close();
this.m_dbConnection = null;
}
}
protected virtual Type ResolveConnectionType()
{
Type type;
try
{
type = SystemInfo.GetTypeFromString(this.m_connectionType, true, false);
}
catch (Exception exception)
{
this.ErrorHandler.Error("Failed to load connection type [" + this.m_connectionType + "]", exception);
throw;
}
return type;
}
protected override void SendBuffer(LoggingEvent[] events)
{
if (this.m_reconnectOnError && ((this.m_dbConnection == null) || (this.m_dbConnection.State != ConnectionState.Open)))
{
LogLog.Debug(declaringType, "OracleAppender: Attempting to reconnect to database. Current Connection State: " + ((this.m_dbConnection == null) ? "<null>" : this.m_dbConnection.State.ToString()));
this.InitializeDatabaseConnection();
this.InitializeDatabaseCommand();
}
if ((this.m_dbConnection != null) && (this.m_dbConnection.State == ConnectionState.Open))
{
if (this.m_useTransactions)
{
OracleTransaction dbTran = null;
try
{
dbTran = this.m_dbConnection.BeginTransaction();
this.SendBuffer(dbTran, events);
dbTran.Commit();
}
catch (Exception exception)
{
if (dbTran != null)
{
try
{
dbTran.Rollback();
}
catch (Exception)
{
}
}
this.ErrorHandler.Error("Exception while writing to database", exception);
}
}
else
{
this.SendBuffer(null, events);
}
}
}
‘叁’ strtus +spring +Hibernate三大框架集成的权限管理系统的源代码
我有
strtus1 +spring +Hibernate写的权限管理系统,数据库mysql
‘肆’ 如何学习吉日嘎拉的走火入魔C#NET通用权限管理系统组件源码
0:视频仔细看看
1:你先把数据库挂上。
2:你把程序配置运行起来。
3:核对操作手册,看看整体功能。
4:看数据库设计。
5:看分层写法。
6:学会用数据库访问层。
7:学会用代码生成器。
8:学会WCF,Remoting等运行模式。
9:Web的例子也看看,如何集成在一起等。
‘伍’ 求java权限管理系统开源代码BS架构,三大框架的,谢谢
‘陆’ 权限管理系统前台用dwz写的后台用ss写的源码下载
首先需要重组下顺序:前台,后台,数据库|操作系统,服务器这样以“|”为分隔符将其分为两部分比较好理解。 前台:就是面向用户的,用户利用这个“前台”来查询需要的信息,他们只有“读”权限。就是说在前台里面他...
‘柒’ 我也需要一个权限管理系统的源代码,您是不是还有啊,能给我发一份吗,谢谢!!
可以通过Bai Hi告知我们
有机会可能完成你所面临的任务
同样的要求也可能告知我们
ES:\\
交易提醒:预付定金是诈骗
‘捌’ Java实现权限管理系统(悬赏100分)
spring security可以实现。。不过spring要升级到3.0
tomcat6。7都能用,我有婉转班。。置于前台菜单用js隐藏也可以,用security判断角色都行,
如果按资源判断就要做acl。。这个很简单。。不过一般初学者要学会spring security至少要1,2个星期吧,如果楼主需要我可以把文档发给你,如果你直接要代码我也可以给你,但你看不懂。。建议还是看文档先把,你留个邮箱给我我发给你。。
‘玖’ 如何学习c#net 通用权限管理系统组件 v3.7 源代码
这个你要去博客园问吉日嘎拉。
‘拾’ 高分求权限管理类的源代码与实例!^_^
游戏点卡系统
实现了权限管理、展示不同用户登陆后拥有不同的菜单项,可以对新角色分配新权限,加入了角色这一感念!实现了一对多的拥有权限!