glassfish hk2_使用GlassFish 3.1.2.2和Primefaces 3.4的JDBC领域和基于表单的身份验证

glassfish hk2

我的博客上最受欢迎的帖子之一是有关JDBC安全领域和带有Primefaces的GlassFish上基于表单的身份验证的简短教程。 在收到有关它不再适用于最新的GlassFish 3.1.2.2的评论后,我认为可能是时候重新访问它并提出更新的版本了。 开始了:

制备

就像在原始教程中一样,我将依靠一些东西。 确保安装了最新的NetBeans 7.3 beta2(包括GlassFish 3.1.2.2)和MySQL Community Server(5.5.x)。 您应该已经验证一切正常,并且可以启动GlassFish并且MySQL Server也已启动。

一些基础

GlassFish身份验证领域,也称为安全策略域或安全域,是GlassFish Server在其上定义和实施通用安全策略的范围。 GlassFish Server已预先配置了文件,证书和管理领域。 此外,您可以设置LDAP,JDBC,摘要,Oracle Solaris或自定义领域。 应用程序可以在其部署描述符中指定要使用的领域。 如果要将应用程序的用户凭据存储在数据库中,则首选是JDBC领域。

准备数据库


启动NetBeans并切换到“服务”选项卡。 右键单击“数据库”节点,然后选择“注册MySQL服务器”。 填写安装细节,然后单击“确定”。 右键单击新MySQL节点,然后选择“连接”。 现在,您将看到所有已经可用的数据库。 再次右键单击并选择“创建数据库”。 输入“ jdbcrealm”作为新的数据库名称。 备注:我们不会使用单独的数据库用户来完成所有这些操作。 强烈建议您这样做,但是我在此示例中使用的是root用户。 如果您有用户,还可以在此处授予对其的完全访问权限。 点击“确定”。 您将自动连接到新创建的数据库。 展开粗体节点,然后右键单击“表”。 选择“执行命令”或通过向导输入表格详细信息。

CREATE TABLE USERS (`USERID` VARCHAR(255) NOT NULL,`PASSWORD` VARCHAR(255) NOT NULL,PRIMARY KEY (`USERID`)
);CREATE TABLE USERS_GROUPS (`GROUPID` VARCHAR(20) NOT NULL,`USERID` VARCHAR(255) NOT NULL,PRIMARY KEY (`GROUPID`)
);

现在,这就是数据库的全部内容。 移至下一段。

让GlassFish了解MySQL

首先要做的是从MySQL网站上获取最新最好MySQL Connector / J,在撰写本文时它为5.1.22。 解压缩mysql-connector-java-5.1.22-bin.jar文件并将其放到您的域文件夹中(例如glassfish \ domains \ domain1 \ lib)。 做完了 现在终于可以创建一个项目了。

基本项目设置

启动一个新的基于Maven的Web应用程序项目。 选择“新建项目”>“ Maven”>“ Web应用程序”,然后单击下一步。 现在输入一个名称(例如secureapp)和所有需要的maven坐标,然后单击下一步。 选择您配置的GlassFish 3+服务器。 选择Java EE 6 Web作为您的EE版本,然后点击“完成”。 现在我们需要在GlassFish域中添加更多配置,右键单击新创建的项目,然后选择``新建>其他> GlassFish> JDBC连接池''。 输入新连接池的名称(例如SecurityConnectionPool),并在“从现有连接中提取:”复选框下方,选择您注册MySQL连接。 点击下一步。 查看连接池属性,然后单击“完成”。 现在,新创建的Server Resources文件夹显示您的sun-resources.xml文件。 遵循步骤并创建一个“新建>其他> GlassFish> JDBC资源”,指向创建的SecurityConnectionPool(例如jdbc / securityDatasource)。您将在名为glassfish-resources.xml的文件“其他源/设置”下找到已配置的内容。 。 它与应用程序一起部署到您的服务器。 因此,您不必在意使用GlassFish管理控制台配置所有内容。此外,我们仍然需要Primefaces。 右键单击您的项目,选择“属性”更改为“框架”类别,然后添加“ JavaServer Faces”。 切换到“组件”选项卡,然后选择“ PrimeFaces”。 单击“确定”完成。 您可以通过打开pom.xml并检查Primefaces依赖项来验证其是否有效。 3.4应该在那里。 随时将版本更改为最新的3.4.2。

最终的GlassFish配置

现在是时候启动GlassFish并进行领域配置了。 在NetBeans中,再次切换到“服务”选项卡,然后右键单击“ GlassFish 3+”节点。 选择“开始”,并观察“输出”窗口是否成功启动。 再次右键单击并选择“查看域管理控制台”,这将打开默认浏览器,将您指向http:// localhost:4848 /。 选择“配置>服务器配置>安全>领域”,然后单击表顶部的“新建...”。 输入名称(例如JDBCRealm),然后从下拉列表中选择com.sun.enterprise.security.auth.realm.jdbc.JDBCRealm。 在文本字段中填写以下值:

贾斯 jdbcRealm
日本国家发展研究院 jdbc / securityDatasource
用户表 使用者
用户名列 用户名
密码栏 密码
组表 团体
组名列 团队名字

保留所有其他默认值/空白,然后在右上角选择“确定”。 您会看到一个漂亮JavaScript警告窗口,该窗口告诉您_not_保留“摘要算法”字段为空。 我发现了一个关于它的错误。 默认为SHA-256。 与3.1之前使用MD5的GlassFish版本不同。 本教程的较旧版本完全不使用摘要算法(“无”)。 这是为了使事情变得容易,但根本不被认为是好的做法。 因此,即使是进行开发,也请坚持使用SHA-256。

保护您的应用程序

完成配置环境。 现在,我们必须实际保护应用程序。 第一部分是考虑要保护的资源。 跳转到您的Web Pages文件夹并创建另外两个文件夹。 一个叫做“管理员”,另一个叫做“用户”。 其背后的想法是,拥有两个单独的文件夹,属于相应组的用户可以访问这些文件夹。 现在我们必须创建一些页面。 打开Web Pages / index.xhtml并将h:body标记之间的所有内容替换为以下内容:

<h:body>Select where you want to go:<br /><h:link outcome='admin/index' value='To the admin section' /><br /><h:link outcome='users/index' value='To the user section' /></h:body>

现在,将新的index.xhtml添加到用户和admin文件夹。 让他们做这样的事情:

<h:body><h1>Hello Admin|User</h1><br /><h:link outcome='/index' value='Back to Homepage' /></h:body>

转到login.xhtml。 在Web文件夹的根目录中使用以下内容创建它。

<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0Transitional//EN' 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd'>
<html xmlns='http://www.w3.org/1999/xhtml'xmlns:p='http://primefaces.org/ui'xmlns:h='http://java.sun.com/jsf/html'><h:head><title>Login Form</title></h:head><h:body><p:panel header='Login From'><form method='POST' action='j_security_check'>Username: <input type='text' name='j_username' />Password: <input type='password' name='j_password' /><br /><input type='submit' value='Login' /><input type='reset' value='Reset' /></form></p:panel></h:body>
</html>

如您所见,它具有基本的Primefaces p:panel组件,该组件具有简单的html形式,该形式指向预定义的动作j_security_check。 这就是所有魔力发生的地方。 您还必须为用户名和密码包含两个输入字段,并使用预定义名称j_username和j_password。 现在,如果用户未输入正确的凭据,我们将创建所显示的loginerror.xhtml。 (使用与上例相同的DOCTYPE和标头)。

<h:body><p:panel header='Login Error'>Sorry, you made an Error. Please try again: <a href='#{facesContext.externalContext.requestContextPath}/' >Login</a></p:panel></h:body>

唯一的魔术是登录锚的href链接。 我们需要获取正确的请求上下文,这可以通过访问faces上下文来完成。 如果没有适当权限的用户尝试访问文件夹,则会看到“ 403访问被拒绝”错误页面。 如果要自定义它,则需要添加它,并将以下几行添加到web.xml中:

<error-page>
<error-code>403</error-code>
<location>/faces/403.xhtml</location>
</error-page>

该片段定义了所有未经授权的请求都应转到403页。 如果您已经打开了web.xml,让我们开始保护您的应用程序。 我们需要为任何受保护的资源添加安全约束。 尽管安全约束对于Java EE Web应用程序的安全至关重要,但它对Web开发人员的了解却很少。 指定URL模式,HTTP方法,角色和传输约束的组合对于程序员或管理员而言可能是艰巨的。 重要的是要意识到,任何旨在安全但未通过安全约束指定的组合都将意味着Web容器将允许这些请求。 安全约束包括Web资源集合(URL模式,HTTP方法),授权约束(角色名称)和用户数据约束(是否需要通过受保护的传输(例如TLS)接收Web请求)。

<security-constraint><display-name>Admin Pages</display-name><web-resource-collection><web-resource-name>Protected Admin Area</web-resource-name><description></description><url-pattern>/faces/admin/*</url-pattern><http-method>GET</http-method><http-method>POST</http-method><http-method>HEAD</http-method><http-method>PUT</http-method><http-method>OPTIONS</http-method><http-method>TRACE</http-method><http-method>DELETE</http-method></web-resource-collection><auth-constraint><description/><role-name>admin</role-name></auth-constraint><user-data-constraint><transport-guarantee>NONE</transport-guarantee></user-data-constraint></security-constraint><security-constraint><display-name>All Access</display-name><web-resource-collection><web-resource-name>None Protected User Area</web-resource-name><description/><url-pattern>/faces/users/*</url-pattern><http-method>GET</http-method><http-method>POST</http-method><http-method>HEAD</http-method><http-method>PUT</http-method><http-method>OPTIONS</http-method><http-method>TRACE</http-method><http-method>DELETE</http-method></web-resource-collection><user-data-constraint><transport-guarantee>NONE</transport-guarantee></user-data-constraint></security-constraint>

如果必须定义约束,那么容器应如何挑战用户。 Web容器可以使用HTTP BASIC,HTTP DIGEST,HTTPS CLIENT或基于FORM的身份验证方案对Web客户端/用户进行身份验证。 在这种情况下,我们使用基于FORM的身份验证并定义JDBCRealm。

<login-config><auth-method>FORM</auth-method><realm-name>JDBCRealm</realm-name><form-login-config><form-login-page>/faces/login.xhtml</form-login-page><form-error-page>/faces/loginerror.xhtml</form-error-page></form-login-config></login-config>

领域名称必须是您之前分配的安全领域的名称。 关闭web.xml并打开sun-web.xml,以进行从应用程序角色名到数据库中实际组的映射。 这种抽象感觉很奇怪,但是有一些原因。 引入它是为了可以将应用程序角色映射到企业中的不同组名。 我从未见过广泛使用该功能,但是该功能已存在,您必须对其进行配置。 其他应用服务器的确假设没有映射,则角色名称和组名称确实匹配。 GlassFish不这么认为。 因此,您必须将以下内容放入glassfish-web.xml中。 您可以通过右键单击项目的WEB-INF文件夹来创建它,然后选择“新建>其他> GlassFish> GlassFish描述符”

<security-role-mapping><role-name>admin</role-name><group-name>admin</group-name></security-role-mapping>

就是说,基本上……您所需的一切都准备就绪。 唯一缺少的是数据库中的用户。 它仍然是空的……我们需要添加一个测试用户:

将测试用户添加到数据库

再一次,我们右键单击NetBeans中“服务”选项卡上的jdbcrealm数据库。 选择“执行命令”并插入以下内容:

INSERT INTO USERS VALUES ('admin', '8c6976e5b5410415bde908bd4dee15dfb167a9c873fc4bb8a81f6f2ab448a918');
INSERT INTO USERS_GROUPS VALUES ('admin', 'admin');

您可以使用用户:admin和密码:admin登录并访问安全区域。 生成哈希的示例代码如下所示:

try {MessageDigest md = MessageDigest.getInstance('SHA-256');String text = 'admin';md.update(text.getBytes('UTF-8')); // Change this to 'UTF-16' if neededbyte[] digest = md.digest();BigInteger bigInt = new BigInteger(1, digest);String output = bigInt.toString(16);System.out.println(output);} catch (NoSuchAlgorithmException | UnsupportedEncodingException ex) {Logger.getLogger(PasswordTest.class.getName()).log(Level.SEVERE, null, ex);}


参考:来自JCG合作伙伴 Markus Eisele的GlassFish 3.1.2.2和Primefaces 3.4的JDBC领域和基于表单的身份验证,来自企业软件开发和Java博客。

翻译自: https://www.javacodegeeks.com/2013/02/jdbc-realm-and-form-based-authentication-with-glassfish-3-1-2-2-and-primefaces-3-4.html

glassfish hk2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349893.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NOIP模拟测试8「匹配·回家」

匹配 哈希能A 水到爆炸 回家 事实上我做过一个原题&#xff0c;甚至比这个回家难的多&#xff0c;而且那个题多组询问必经点 然后我做一组询问就打炸了 大约就是删了很多东西&#xff0c;然后自己想的太简单了 直接统计了割点&#xff0c;懒得打lca和树上差分&#xff0c;懒得打…

将CloudWatch Logs与Cloudhub Mule集成

在此博客中&#xff0c;我将解释如何为您的Mule CloudHub应用程序启用AWS Cloudwatch日志 。 AWS提供了Cloudwatch Logs Services&#xff0c;以便您可以更好地管理日志。 它比松散便宜。 由于cloudhub会自动翻转超过100 MB的日志&#xff0c;因此我们需要一种机制来更有效地管…

android网络重试机制,okhttp源码解析(四):重试机制

前言这一篇我们分析okhttp的重试机制&#xff0c;一般如果网络请求失败&#xff0c;我们会考虑连续请求多次&#xff0c;增大网络请求成功的概率&#xff0c;那么okhttp是怎么实现这个功能的呢&#xff1f;正文首先还是回到之前的InterceptorChain&#xff1a;Response getResp…

构造入门

构造死磕 什么是构造 小学中学奥数先用数学解决再编程实现的构造题一般算法无法解决\(NOI\)难度\(PJ-\)代码量坑构造举例 CF743C Vladik and fractions 题目让我们构造一组数字,满足\(\frac{2}{n} \frac{1}{x} \frac{1}{y} \frac{1}{z}\)第一眼看到就想到听老师讲了半天才知…

王成录华为鸿蒙系统,华为手机销量仍在增长!华为王成录:手机会是鸿蒙OS系统的中心...

【天极网手机频道】由于制裁&#xff0c;华为遭到前所未有的断供&#xff0c;外界有不少声音都在担心华为手机出货量将会出现暴跌。不过昨日华为开发者大会举办期间&#xff0c;华为消费者业务软件部总裁王成录表示&#xff0c;华为手机销量仍在增长中。昨天的华为开发者大会&a…

28线程

进程&#xff1a;计算机执行的任务 线程&#xff1a;执行任务中的小任务 多线程 计算机再执行过程中&#xff0c;再同一时间只能让cpu的一个核执行一个进程。进程有多个线程构成&#xff0c;再同一时刻Cpu只能处理一个线程。 引入多线程 当线程被cpu执行时cpu开始工作&#xff…

什么是javax.ws.rs.core.context? [第3部分]

如何使用Context批注 在什么是javax.ws.rs.core.context的第2部分中&#xff1f; 您学习了如何使用Context批注从SecurityContext类的注入实例检索安全信息&#xff0c;以及如何通过ResourceContext实例使用JAX-RS资源类。 在本文中&#xff0c;您将学习如何将Context批注与请…

html 字幕飘动效果,html 滚动字幕 制作滚动字幕效果 参数

制作滚动字幕效果&#xff1a;marquee标签 如下:&#xff1c;MARQUEE directionup height146 οnmοuseοutstart() οnmοuseοverstop() scrollAmount4&#xff1e; &#xff1c;/marquee&#xff1e;参数说明&#xff1a;direction滚动方向&#xff1a;up向上滚动&#xff0…

静态点分治总结

点分治是世界上最好的算法QwQ 点分治可以解决各种树上的边权点权问题&#xff0c;然后如果你发现这个题好像问的特别玄学&#xff0c;lca&#xff0c;树差都做不了&#xff0c;树上动‘龟’更做不了&#xff0c;只能暴力时&#xff0c;这个题大多数情况就是点分治了 点分治的思…

html节点上下移动,关于前端:数组元素上下移动

/*** 上、下挪动* param {number} code 下标* param {number} dir 1上移 0下移*/onMove(code, dir) {let moveComm (curIndex, nextIndex) > {let arr this.commodityInfoarr[curIndex] arr.splice(nextIndex, 1, arr[curIndex])[0]return arr}this.commodityInfo.some((…

mybatis插入数据后返回自增主键ID详解

1.场景介绍: ​ 开发过程中我们经常性的会用到许多的中间表,用于数据之间的对应和关联.这个时候我们关联最多的就是ID,我们在一张表中插入数据后级联增加到关联表中.我们熟知的mybatis在插入数据后返回的是插入成功的条数,那么这个时候我们想要得到相应的这条新增数据的ID,该怎…

spring 属性占位符_Spring属性占位符配置器–一些不太明显的选项

spring 属性占位符Spring的PropertySourcesPlaceholderConfigurer用于从XML或Java Config中定义的Spring bean定义外部化属性。 PlaceholderConfigurer支持的一些选项在文档中并不明显&#xff0c;但很有趣&#xff0c;并且可能有用。 首先&#xff0c;以Spring文档中的示例为…

红包雨效果html,js+css实现红包雨效果

//每一个红包都是相对于父元素定位&#xff0c;通过z-index来设置层级let zIndex 1;function bindEvent() {$redPackage.on(click,.js-RedPackageBox,function() {//拿到每个红包的数据const data $(this).data(txt);}}//生成mix-max的随机数function getRandom(min,max) {re…

Delphi下实现全屏快速找图找色 二、矩阵遍历

二、矩阵遍历  矩阵遍历是一个数据结构方面的问题。假设有一个矩阵Matrix&#xff0c;它共有RowCount行&#xff0c;每行有ColCount列&#xff0c;当利用y表示行数&#xff0c;x表示列数&#xff0c;那么利用Matrix[y,x]就可以访问矩阵中的任意元素。假设有一个1010大小的矩阵…

Eclipse MicroProfile:您需要了解的5件事

针对微服务架构优化企业Java Eclipse MicroProfile计划是在JavaOne 2016上发起的&#xff0c;JavaOne是服务器供应商和Java用户组的创意&#xff0c;目的是解决企业Java微服务领域的缺点。 Java EE的发布速度减慢到无法应对Swift发展的微服务趋势的挑战的程度。 MicroProfile通…

html 选择不能重复,人生,就是一次无法重复的选择(深度好文)

作者&#xff1a;彩云追月欧洲著名的政治家托马斯 莫尔说&#xff1a;“在人生中最艰难的是选择”。漫漫人生路&#xff0c;有无数的选择&#xff0c;不同的选择&#xff0c;可能会决定我们不同的人生道路。下面的故事也许对你有所启迪&#xff1a;一天&#xff0c;几个学生问…

用HTML做软件UI用到的的一些技术

做WEB开发的想把网页做成应用程序的界面&#xff0c;开发应用程序的又想把程序界面做得和WEB一样。本文介绍一下用HTML做软件UI用到的的一些技术。 其实HTML UI也不是什么新鲜事了&#xff0c;Norton Antivirus从几年前的版本就开始用了&#xff0c;vs.net2002中的开始页也用了…

html css导航栏字体图标,HTML+CSS入门之两种图标字体库

本篇教程介绍了HTMLCSS入门之两种图标字体库&#xff0c;希望阅读本篇文章以后大家有所收获&#xff0c;帮助大家HTMLCSS入门。<## 0. 前言比较基础的图标加载&#xff1a;和块元素的背景background: url(./x.png).页面多图标时&#xff0c;使用雪碧图(多个png压缩成一个png…

垃圾收集算法,垃圾收集器_弱,弱,最弱,利用专家参考来管理垃圾收集器

垃圾收集算法,垃圾收集器何时以及何时不使用Java中的专家引用 弱引用&#xff0c;软引用和幻像引用既危险又强大。 如果以错误的方式使用它们&#xff0c;则会破坏JVM性能。 但是&#xff0c;如果使用正确的方法&#xff0c;它们可以大大提高性能和程序清晰度。 弱引用和软引用…

ESP8266—“ICACHE_FLASH_ATTR”宏

问&#xff1a;ESP8266_NONOS_SDK中ICACHE_FLASH_ATTR宏的用途是什么&#xff1f;我看到它取决于ICACHE_FLASH&#xff0c;但我不知道何时应该定义该符号。什么时候需要包括它&#xff1f;答&#xff1a;对于ESP8266_NONOS_SDK&#xff0c;用ICACHE_FLASH_ATTR编译的函数编译到…