java web项目war包部署,使用tomcat对指定接口设置身份认证
先简单说一下需求:
将一个基于springboot2.0开发的java web项目打成war包,通过tomcat部署到一台linux服务器上,项目相关的一些图片等资源也按照一定规则放置在服务器构建好的目录下。现在需要让用户通过http网页链接的方式(在浏览器端)访问图片,为了访问安全,需要在中间加一层用户认证。认证过程希望尽量简单些,所以就尝试用tomcat自带的身份认证来做。
话不多说,直接上实现流程:
首先,由于要访问本地的静态资源,所以在springboot启动类中加了一项静态资源的映射,使用/image映射本地的/home/zxx/darknet/test目录:
public class FilemicroserviceApplication extends WebMvcConfigurationSupport {
@Value("${BASEDIR}")
String BASEDIR; // 本地资源文件根目录
public static void main(String[] args) {
SpringApplication.run(FilemicroserviceApplication.class, args);
}
/**
* 静态资源映射器
* @param registry
*/
@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/image/**").addResourceLocations("file:"+BASEDIR+"/");
}
}
然后,将项目打成war包,我的war包名称为filemicroservice.war,部署到linux服务器tomcat上(即放置在tomcat的webapps目录下):

在tomcat的conf目录下需要配置两个文件:
在tomcat-users.xml文件<tomcat-users></tomcat-users>中加上两条代码,设置访问认证的用户角色和该角色的用户账号和密码,此处,我设置了一个名为uav的角色,并且添加了一个账号为uav,密码为123456,角色为uav的用户:
<role rolename="uav"/>
<user username="uav" password="123456" roles="uav"/>
接下来在web.xml中设置身份认证,直接翻到文件最下面,在尾标签</web-app>上方加上这块代码:
<security-constraint>
<web-resource-collection>
<!--项目名称(即放置在webapps下的war包名称)-->
<web-resource-name>filemicroservice</web-resource-name>
<!--需要安全认证的接口-->
<url-pattern>/image/*</url-pattern>
</web-resource-collection>
<auth-constraint>
<!-- 只允许uav角色的用户访问 -->
<role-name>uav</role-name>
</auth-constraint>
</security-constraint>
<login-config>
<!--值可以是BASIC/DIGEST/CLIENT_CERT/FORM-->
<auth-method>BASIC</auth-method>
<!--认证提示信息-->
<realm-name>请输入认证用户的账号密码</realm-name>
</login-config>
<security-role>
<role-name>uav</role-name>
</security-role>
修改保存好上述两个文件后,到bin目录下,通过命令启动tomcat./startup.sh,然后去浏览器通过http访问服务器指定目录下的静态文件:

我在/image映射的目录下存放了一个文件夹,里面放有两张图片,现在,我们通过http去访问图片,浏览器会弹出一个身份认证的弹框:

然后我们输入在tomcat中设置的用户账号和密码,确认访问:

成功了。
java web项目war包部署,使用tomcat对指定接口设置身份认证的更多相关文章
- 将Web项目War包部署到Tomcat服务器
1. 配置Java运行环境 1.1 下载并安装JDK 从官网上下载最新的JDK:http://java.sun.com/javase/downloads/index.jsp ,下载后安装,选择想把JD ...
- IntelliJ IDEA打包WAR并部署运行(mac osx)将Web项目War包部署到Tomcat服务器基本步骤(完整版)
用IntelliJ IDEA做web开发体验很好,但导出war包比eclipse麻烦了不少,以下是解决方案: 打包:1.自动打包:File —> Project Structure —> ...
- 将Web项目War包部署到Tomcat服务器基本步骤
参考来源: http://www.cnblogs.com/pannysp/archive/2012/03/07/2383364.html 1. 常识: 1.1 War包 War包一般是在进行Web ...
- 将Web项目War包部署到Tomcat服务器基本步骤(完整版)
1. 常识: 1.1 War包 War包一般是在进行Web开发时,通常是一个网站Project下的所有源码的集合,里面包含前台HTML/CSS/JS的代码,也包含Java的代码. 当开发人员在自己 ...
- 将web项目打成war包部署在tomcat步骤
将web项目打成war包部署在tomcat步骤 1.将自己的项目打成war包. 2.将打包好的war复制到${tomcat.home}/webapps项目下. 3.在${tomcat.hom}/con ...
- IDEA多模块父子依赖maven项目war包部署
IDEA多模块父子依赖maven项目war包部署 Posted on 2018-04-25 | In IDEA | | Visitors 286 IDEA全称为IntrlliJ IDEA,它是一款非常 ...
- SpringBoot之打成war包部署到Tomcat
正常情况下SpringBoot项目是以jar包的形式,正常情况下SpringBoot项目是以jar包的形式,并且SpringBoot是内嵌Tomcat服务器,所以每次重新启动都是用的新的Tomcat服 ...
- Eclipse中的Web项目自己主动部署到Tomcat
一.原因. 1.写java程序有一段时间了,但非常久没用eclipse了.所以使用eclipse编写的web项目部署到tomcat 的方式也不是非常清楚,以下记录一下将Eclipse 上的web项目自 ...
- springmvc项目打war包部署到tomcat访问路径去掉项目名
一般来说,部署到tomcat则是把war包丢到webapps目录下,启动Tomcat会自动解压,成一个war包名称的文件夹项目, 例如imgManager.war 访问的地址一般是localhost: ...
随机推荐
- 了解Spring的基本概念
参考资料:https://www.jianshu.com/p/1c483bd8fd6d 在正式学习Spring框架之前,肯定有很多疑问,比如说: 1.Spring中经常出现的IOC.AOP.DI是什么 ...
- 技术人如何利用 github+Jekyll ,搭建一个独立免费的技术博客
上次有人留言说,技术博客是程序员的标配,但据我所知绝大部分技术同学到现在仍然没有自己的技术博客.原因有很多,有的是懒的写,有的是怕写不好,还有的是一直想憋个大招,幻想做到完美再发出来,结果一直胎死腹中 ...
- ETCD:单机单节点
原文地址:Setting up local clusters 设置单节点集群 对于测试环境与开发环境,最快速与简单的方式是配置一个本地集群.对于生产环境,参考集群部分. 本地单节点集群 启动一个集群 ...
- code migrate
1. 从Git上clone 仓库到本地. git clone --mirror http://gittest:gittest@192.168.1.x/x.git 2. push 到codecommit ...
- go modules 学习
go modules 学习 tags:golang 安装 只需要golang的版本是1.11及之后的,这个模块就内置好了 环境变量 (1) 配置GoLang的GOROOT (2) 可以不配置GoLan ...
- docker实例之mysql的使用
docker实例之mysql的使用 常用步骤 命令 1:搜索镜像 docker search xxx 2:拉取镜像 docker pull xxx:yy 3:查看镜像 docker image ins ...
- Rust更换Crates源
Rust编译时遇到如下问题: Downloading futures v0.1.19 warning: spurious network error (2 tries remaining): [28] ...
- 教你用Java web实现多条件过滤功能
生活中,当你闲暇之余浏览资讯的时候,当你搜索资料但繁杂信息夹杂时候,你就会想,如何更为准确的定位需求信息.今天就为你带来: 分页查询 需求分析:在列表页面中,显示指定条数的数据,通过翻页按钮完成首页/ ...
- HTML 空元素(转)
HTML 空元素 在 HTML 中,通常在一个空元素上使用一个闭标签是无效的.例如,<input type="text"> </input> 的闭标签是无效 ...
- csrf与xss
CSRF攻击攻击原理及过程如下: 1. 用户C打开浏览器,访问受信任网站A,输入用户名和密码请求登录网站A: 2.在用户信息通过验证后,网站A产生Cookie信息并返回给浏览器,此时用户登 ...