- 浏览: 13769 次
- 性别:
- 来自: 十堰
最新评论
-
zhchyun2008:
标记下 学习了
Flex特效的几个网站 -
hyx0914:
太好了,谢谢了~!
Flex特效的几个网站 -
xmzrx:
[list]
引用这些特效太牛X啦... 就是没有源码可以看的 ...
Flex特效的几个网站
这两天看BlueDavy写的一篇OSGi入门的文章《OSGi实战》,在道客巴巴有这篇文章的链接。
在这篇文章里面有这样一个例子:一个网站,有一个验证用户名和密码的页面(UserValidatorWebBundle)。验证的方式有三种:LDAP验证(LDAPValidatorBundle)﹑数据库验证(DBValidatorBundle)和配置文件验证(ConfigValidatorBundle)。在OSGi框架来讲,这分别是四个Bundle,UserValidatorWebBundle提供前端Web访问服务,执行时需要调用到三个验证Bundle中某一个提供的验证服务。三个验证Bundle在实际环境下可以通过启动其中一个﹑停止其它两个的方法实现动态的改变验证方式。
另外,还有一个UserValidatorBundle,这个Bundle实际上只包含了一个验证服务的接口类,在LDAPValidatorBundle﹑DBValidatorBundle和ConfigValidatorBundle三个Bundle之间提供验证服务的公共定义。
特别说明,我的开发环境是Eclipse JaveEE Indigo 3.7.2。
实现UserValidatorBundle
UserValidatorBundle提供验证服务的接口类Validator。由于它不要注册任何的服务和监听器,因此这里我们不需要为该Bundle提供Activator实现。它的作用就是将验证接口Validator通在MANIFEST.MF的Export-Package导出去,然后供其它具体实现验证服务的Bundle使用。
Bundle的详细开发过程可以参考《OSGi系列 - 用Eclipse开发Bundle》,这里只对关键地方进行说明。
UserValidatorBundle的目录结构,注意该Bundle没有Activator类:
Validator.java文件内容:
package org.riawork.demo.service.user; public interface Validator { public boolean validate(String username, String password) throws Exception; }
打开MANIFEST.MF文件,在出现的元数据编辑页面中选择底部的Runtime标签页,然后点击Exported Packages旁边的Add...按钮,添加如下的内容:
这个操作实际上就是在MANIFEST.MF文件里面增加一条Export-Package项目:
Export-Package: org.riawork.demo.service.user
MANIFEST.MF文件完整的内容:
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: UserValidatorBundle Bundle-SymbolicName: UserValidatorBundle Bundle-Version: 1.0.0 Import-Package: org.osgi.framework;version="1.3.0" Bundle-RequiredExecutionEnvironment: JavaSE-1.6 Export-Package: org.riawork.demo.service.user
实现LDAPValidatorBundle
LDAPValidatorBundle提供LDAP验证方式。
LDAPValidatorBundle提供了一个LDAPValidator验证类,该类需要实现UserValidatorBundle里面的Valdiator接口,因此需要在MANIFEST.MF文件中通过Import-Package导入Validator接口所在的包org.riawork.demo.service.user。
LDAPValidatorBundle同时也提供了一个LDAPActivator类,用来管理Bundle的生命周期,在start()和stop()方法中实现LDAPValidator验证服务的注册和卸载。
作为演示用途,这里所有的验证方式都使用的是字符串硬编码的简单方式。
LDAPValidatorBundle的目录结构:
打开MANIFEST.MF文件,在出现的元数据编辑页面中选择底部的Dependencies标签页,然后点击Imported Packages旁边的Add...按钮,添加如下的内容:
这个操作实际上就是在MANIFEST.MF文件里面增加一条Import-Package项目:
Import-Package: org.osgi.framework;version="1.3.0",
org.riawork.demo.service.user
MANIFEST.MF文件完整的内容:
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: LDAPValidatorBundle Bundle-SymbolicName: LDAPValidatorBundle Bundle-Version: 1.0.0 Bundle-Activator: org.riawork.demo.service.user.impl.LDAPActivator Import-Package: org.osgi.framework;version="1.3.0", org.riawork.demo.service.user Bundle-RequiredExecutionEnvironment: JavaSE-1.6
LDAPValidator.java文件内容:
package org.riawork.demo.service.user.impl; import org.riawork.demo.service.user.Validator; public class LDAPValidator implements Validator { public boolean validate(String username, String password) throws Exception { System.out.println("LDAPValidator.validate()方法被调用"); if ("jerry".equals(username) && "jerry".equals(password)){ return true; } return false; } }
LDAPActivator.java文件内容:
package org.riawork.demo.service.user.impl; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceRegistration; import org.riawork.demo.service.user.Validator; public class LDAPActivator implements BundleActivator { private ServiceRegistration serviceReg = null; public void start(BundleContext bundleContext) throws Exception { System.out.println("LDAPValidator服务被注册"); serviceReg = bundleContext.registerService(Validator.class.getName(), new LDAPValidator(), null); } public void stop(BundleContext bundleContext) throws Exception { if(serviceReg != null) serviceReg.unregister(); System.out.println("LDAPValidator服务被卸载"); } }
实现DBValidatorBundle
DBValidatorBundle提供数据库验证方式,该Bundle的实现方式完全同LDAPValidatorBundle。
DBValidatorBundle的目录结构:
MANIFEST.MF文件内容:
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: DBValidatorBundle Bundle-SymbolicName: DBValidatorBundle Bundle-Version: 1.0.0 Bundle-Activator: org.riawork.demo.service.user.impl.DBActivator Import-Package: org.osgi.framework;version="1.3.0", org.riawork.demo.service.user Bundle-RequiredExecutionEnvironment: JavaSE-1.6
DBValidator.java文件内容:
package org.riawork.demo.service.user.impl; import org.riawork.demo.service.user.Validator; public class DBValidator implements Validator { public boolean validate(String username, String password) throws Exception { System.out.println("DBValidator.validate()方法被调用"); if ("jerry".equals(username) && "jerry".equals(password)){ return true; } return false; } }
DBActivator.java文件内容:
package org.riawork.demo.service.user.impl; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceRegistration; import org.riawork.demo.service.user.Validator; public class DBActivator implements BundleActivator { private ServiceRegistration serviceReg = null; public void start(BundleContext bundleContext) throws Exception { System.out.println("DBValidator服务被注册"); serviceReg = bundleContext.registerService(Validator.class.getName(), new DBValidator(), null); } public void stop(BundleContext bundleContext) throws Exception { if(serviceReg != null) serviceReg.unregister(); System.out.println("DBValidator服务被卸载"); } }
实现ConfigValidatorBundle
ConfigValidatorBundle提供配置人家验证方式,该Bundle的实现方式完全同LDAPValidatorBundle。
ConfigValidatorBundle的目录结构:
MANIFEST.MF文件内容:
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: ConfigValidatorBundle Bundle-SymbolicName: ConfigValidatorBundle Bundle-Version: 1.0.0 Bundle-Activator: org.riawork.demo.service.user.impl.ConfigActivator Import-Package: org.osgi.framework;version="1.3.0", org.riawork.demo.service.user Bundle-RequiredExecutionEnvironment: JavaSE-1.6
ConfigValidator.java文件内容:
package org.riawork.demo.service.user.impl; import org.riawork.demo.service.user.Validator; public class ConfigValidator implements Validator { public boolean validate(String username, String password) throws Exception { System.out.println("ConfigValidator.validate()方法被调用"); if ("jerry".equals(username) && "jerry".equals(password)){ return true; } return false; } }
ConfigActivator.java文件内容:
package org.riawork.demo.service.user.impl; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceRegistration; import org.riawork.demo.service.user.Validator; public class ConfigActivator implements BundleActivator { private ServiceRegistration serviceReg = null; public void start(BundleContext bundleContext) throws Exception { System.out.println("ConfigValidator服务被注册"); serviceReg = bundleContext.registerService(Validator.class.getName(), new ConfigValidator(), null); } public void stop(BundleContext bundleContext) throws Exception { if(serviceReg != null) serviceReg.unregister(); System.out.println("ConfigValidator服务被卸载"); } }
实现UserValidatorWebBundle
UserValidatorWebBundle提供使用者前端访问。该Bundle提供一个login.html页面,输入用户名和密码后,点击登录按钮,将数据提交到LoginServlet。LoginServlet检查,获取已经注册的Validator验证服务,调用validate()方法检查传过来的用户名和密码是否正确。
该Bundle使用到了Servlet API和HTTP服务,因此必需javax.servlet和org.eclipse.osgi.services两个额外的Bundle。
UserValidatorWebBundle的目录结构:
打开MANIFEST.MF文件,选择底部的Dependencies标签页,添加如下的内容:
这个操作实际上就是在MANIFEST.MF文件里面增加Import-Package项目和Require-Bundle项目:
Import-Package: org.osgi.framework;version="1.3.0", org.riawork.demo.service.user Require-Bundle: javax.servlet;bundle-version="2.5.0", org.eclipse.osgi.services;bundle-version="3.3.0"
MANIFEST.MF文件完整的内容:
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: UserValidatorWebBundle Bundle-SymbolicName: UserValidatorWebBundle Bundle-Version: 1.0.0 Bundle-Activator: org.riawork.demo.web.Activator Import-Package: org.osgi.framework;version="1.3.0", org.riawork.demo.service.user Bundle-RequiredExecutionEnvironment: JavaSE-1.6 Require-Bundle: javax.servlet;bundle-version="2.5.0", org.eclipse.osgi.services;bundle-version="3.3.0"
在src目录下新建page目录,然后在page目录下新增login.html文件。login.html文件内容:
<HTML> <HEAD> <TITLE>OSGI Opendoc Demo</TITLE> <meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> <script> function login(){ if(document.frmLogin.username.value==""){ alert("必须输入用户名"); document.frmLogin.username.focus(); return; } if(document.frmLogin.userpass.value==""){ alert("必须输入密码"); document.frmLogin.userpass.focus(); return; } document.frmLogin.submit(); } </script> </HEAD> <BODY> <table style="width:45%;border:1px solid;height:100px"> <form name=frmLogin method="post" action="/demo/login"> <tr bgcolor="#C0C0C0"> <td colspan="2" align="center">用户登录模块示例</td> </tr> <tr> <td width="30%">用户名</td> <td><input type="text" name="username" size="30"></td> </tr> <tr> <td>密 码</td> <td><input type="password" name="userpass" size="33"></td> </tr> <tr bgcolor="#C0C0C0"> <td colspan="2" align="center"> <input type=button name=btnSubmit value="登录" onclick="login();"> </td> </tr> </form> </table> </BODY> </HTML>
LoginServlet.java文件内容:
package org.riawork.demo.web; import java.io.IOException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceReference; import org.riawork.demo.service.user.Validator; public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; private BundleContext context; public LoginServlet(BundleContext context){ this.context=context; } /** * Web Post Method */ public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException{ doGet(request, response); } /** * Web GET Method */ public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException{ String username=request.getParameter("username"); String userpass=request.getParameter("userpass"); response.setContentType("text/html"); ServletOutputStream output=response.getOutputStream(); ServiceReference serviceRef=context.getServiceReference(Validator.class.getName()); Validator validator=(Validator) context.getService(serviceRef); if(validator==null){ output.println("No usable validator service"); output.close(); return; } boolean result=false; try { result=validator.validate(username, userpass); if(result) output.println("Login success"); else output.println("Login Fail,please check username and password"); output.close(); return; } catch (Exception e) { output.println("Login error:"); output.println(e.toString()); return; } } }
Activator.java文件内容:
package org.riawork.demo.web; import javax.servlet.Servlet; import org.osgi.framework.BundleActivator; import org.osgi.framework.BundleContext; import org.osgi.framework.ServiceEvent; import org.osgi.framework.ServiceListener; import org.osgi.framework.ServiceReference; import org.osgi.service.http.HttpService; import org.riawork.demo.web.LoginServlet; public class Activator implements BundleActivator,ServiceListener{ private BundleContext bc; private ServiceReference ref; private Servlet servlet; public void start(BundleContext context) throws Exception { bc=context; servlet=new LoginServlet(bc); registerServlet(); context.addServiceListener(this, "(objectClass=" + HttpService.class.getName() + ")"); } public void stop(BundleContext context) throws Exception { try { unregisterServlet(); } catch (Throwable t) { t.printStackTrace(); } servlet = null; bc = null; ref = null; } public void serviceChanged(ServiceEvent event) { switch (event.getType()){ case ServiceEvent.REGISTERED: registerServlet(); break; case ServiceEvent.UNREGISTERING: unregisterServlet(); break; } } private void registerServlet() { if (ref == null) ref = bc.getServiceReference(HttpService.class.getName()); if (ref != null) { try { HttpService http = (HttpService) bc.getService(ref); http.registerServlet("/demo/login", servlet, null, null); http.registerResources("/demo/page","page",null); System.out.println("已启动用户登录验证web模块,请通过/demo/page/login.htm访问"); } catch (Exception e) { e.printStackTrace(); } } } private void unregisterServlet() { if (ref != null) { try { HttpService http = (HttpService) bc.getService(ref); http.unregister("/demo/login"); http.unregister("/demo/page"); System.out.println("已卸载用户登录验证web模块!"); } catch(Exception e){ e.printStackTrace(); } } } }
创建OSGi Run Configuration
选择菜单Run >> Run Configurations...,在弹出的Run Configurations对话框左边找到OSGi Framework,在该项目上点击鼠标右键选择New菜单项,画面如下:
下表的Bundle在Run Configurations对话框中必须被选中:
- UserValidatorBundle
- LDAPValidatorBundle
- DBValidatorBundle
- ConfigValidatorBundle
- UserValidatorWebBundle
- javax.servlet
- org.eclipse.osgi.services
- org.eclipse.equinox.http.servlet
- org.eclipse.equinox.http.jetty
- org.mortbay.jetty.server
- org.mortbay.jetty.util
配置完毕后,点击右下角的Run按钮,启动OSGi框架。如果一切正常,就会出现osgi>提示符,以及Bundle被启动时输出的提示信息:
从上图我们应该发现一个问题,实际上三个不同的验证方式都被启动了。
动态的切换验证方式
打开浏览器,输入http://localhost/demo/page/login.html,出现输入用户名和密码画面:
输入一个用户名和密码(正确的是jerry和jerry),点击登录按钮,浏览器网址转到了http://localhost/demo/login,这实际上就是我们注册的LoginServlet(参考UserValidatorWebBundle的Activator.java文件)。
请注意,这个时候我们查看OSGi控制台,有看到一条信息“ConfigValidator.validate()方法被调用”,说明当前使用的验证方式是配置文件验证。因为我们提供的三种验证服务都被启动了,换句话说,在OSGi框架中,Validator服务有三个提供者,在服务被调用时具体用的是哪一个提供者会由OSGi框架随机的决定。
停止Config和DB验证,只启动LDAP验证,然后再次提交http://localhost/demo/page/login.html,观察OSGi控制台,发现这次使用的是LDAP验证。
停止LDAP和Config验证,启动DB验证,观察OSGi控制台,是不是就是我们所期望的DB验证?
这篇文章实在是有点太长了,对于没耐心从头看到尾的朋友,下面提供了一个压缩文件下载链接,希望能帮助你省一点点时间。
- osgi-user-valiator-code.rar (30.2 KB)
- 下载次数: 8
发表评论
文章已被作者锁定,不允许评论。
相关推荐
内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。
深圳建设施工项目安全生产奖惩管理制度
离散数学课后题答案+sdut往年试卷+复习提纲资料
04741计算机网络原理 2018(尚德).pdf 13年试题(2套).pdf 2015年10月自考计算机网络原理04741试题及答案解析.docx 2021年4月自考04741计算机网络原理真题及答案.docx 2021年4月自考04741计算机网络原理试卷.bak.docx 计算机网络原理 课后题答案 全 李全龙版 自考04741.zip.zip 计算机网络原理课件 计算机网络原理课件.rar
C++实现rpc,全程手写
前端拿到的列表数据里id都一样的处理办法.txt
最新仿720云全景制作源码|krpano仿720云全景网站源码(新增微信支付+打赏+场景红包等)是一款基于php+mysql开发制作的全景在线制作网站源码,包含全景图片,全景视频等。数据存储全部存于OSS云端或本地,源码完全开源可自行二次开发。 环境要求:PHP5.5.X+MYSQL5.6.X+伪静态 熟悉linux系统推荐使用LAMP,web服务器最好使用apache,不要使用nginx(发布大全景图需要时间可能需要20多分钟, nginx超时机制不好控制)。 Windows系统推荐使用phpstudy。Liunx推荐宝塔控制面板apache 前端为HTML5开发,自适应手机版! 1、支持VR虚拟现实、全景视频、环物全景、说一说、点赞评论、重力感应、智能视频嵌入、场景切换热点、加载进度条、 地图导航、光晕flash特效、物体全景嵌入、场景自播、场景解说、雷达导航等业内前沿功能。 2、支持windows、Linux、Mac、安卓、IOS等几乎所有的系统观看。支持CDN图片转存,极大的减轻的服务器流量费用。 3、支持用户权限分配。方便会员制收费。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
环境监测系统源代码全套技术资料.zip
Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
四轮转向系统横摆角速度控制simulink仿真模型,利用滑模控制算法,基于八自由度车辆模型,控制有比较好的效果,附参考说明。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
02142数据结构导论历年真题及答案(2012-2018共13套).rar 02331数据结构历年真题共267页2009.10-2019.4.rar 24数据结构201704_8.pdf 25数据结构201710_10.pdf 26数据结构201804_11.pdf 27数据结构201810_9.pdf 全国2021年04月高等教育自学考试02331数据结构试题及答案.docx 全国2022年04月高等教育自学考试02331数据结构试题及答案.docx 数据结构-课件.rar 第l六讲.ppt 第一讲.ppt 第七讲.ppt 第三讲.ppt 第九讲.ppt 第二讲.ppt 第五讲.ppt 第八讲.ppt 第四讲.ppt
验收确认单表格.docx
内存搜索工具(易).rar
饮食管理系统项目源代码全套技术资料.zip
【项目简介】 代码主干网络采用Swin-Transformer 家族系列,包括【tiny、small、base】三种模型。pretrained和freeze_layers参数为是否采用官方预训练模型和是否仅训练分类头。为了做对比消融试验,优化器采用了Adam和SGD、AdamW三种。损失函数采用多类别的交叉熵、学习率优化策略采用cos余弦退火算法 【评估网络】 评估的指标采用loss和准确率(accuracy),分别会在训练集和验证集上进行评估、输出、绘制曲线图像。同时会在训练集、验证集进行一系列评估,包含混淆矩阵、recall、precision、F1 score等等曲线图像,以及recall、precision、F1 score、特异度的输出信息等等。 【具体各类别的指标在json文件中查看】 【如果想要更换数据集训练,参考readme文件】 【本项目为8种番茄病害图片(约4k张数据),包含数据集和标签,可以一键运行】
windows电脑下载OpenHarmony鸿蒙命令行工具hdc_std。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。
本项目可以作为小程序毕设项目,主要功能为音乐播放器,主要功能是:可以播放歌曲(采用mp3网络连接实现)、专辑封面播放时可以旋转,能够实现开始和暂停播放,可以点击下一首歌曲,主页面实现动态轮播图
考研学习分享功能的描述可以涵盖以下几个主要模块,旨在为考研学生提供一个互动、资源共享、经验交流的平台: 1. 用户注册与个人信息管理 学生可以通过邮箱或手机号注册账户,填写个人信息,如姓名、专业、目标院校等。 用户可设置学习目标和进度,方便记录自己的学习历程。 2. 学习资料共享 用户可以上传、下载考研相关学习资料,如教材、真题、笔记、复习计划等。 提供文件分类功能,按学科、院校、难度等进行整理,方便用户查找。 支持多种文件格式,如PDF、Word、Excel、图片等。 3. 复习经验分享 学生可以发布自己的复习经验文章,分享复习方法、备考心得、时间管理技巧等。 提供文章评论和互动功能,其他学生可以点赞、评论、提问,促进经验交流。 设置专栏或专题,帮助学生快速找到自己感兴趣的复习内容。 4. 考研小组与社交功能 学生可以创建或加入学习小组,组内成员可共享资料、讨论问题、互相鼓励。 提供私信、群聊功能,方便学员在小组内进行实时讨论和交流。 支持设置小组学习目标和定期检查进度,增加学习动力。 5. 在线课程与讲座 提供考研各科目(如英语、数学、政治等)的在线课程资源,用户可以报名参加。