从头开始之JSP+Servlet
前言
本篇包括 Mac 下的 Eclipse 环境搭建,配置 Tomcat 服务器,一个简单的登录页面Demo,包括后台到数据库的一系列逻辑,以及使用到了这几天刚学的 AngularJS 做的页面。
因为 AngularJS4 版本太新了,中文官网没有足够的以 JavaScript 为开发语言的文档,所以先看了AngularJS 2.0之前的文档,先放下以后有时间再看。
从 AngularJS 2 开始官方就推荐使用 TypeScript 。TypeScript是微软开发的开源编程语言,它是JavaScript的一个严格超集,所以任何现有的JavaScript程序都是合法的TypeScript程序。
以下是我学习的资料:
- 官方文档
- 菜鸟 AngularJS
- 菜鸟 AngularJS2
- 慕课 AngularJS 实战
Eclipse 搭建 Tomcat 环境
一、下载Eclipse
选择 最新 的版本。注意,选择 Eclipse IDE for Java EE Developers
这个版本,选择好对应的操作系统和位数,然后点击 Download 即可。
二、下载Tomcat
这里,我选择的是 Tomcat 7.0,我们可以根据需要下载适合自己的版本。
解压缩下载的tomcat文件之后,进入 tomcat 的 bin
目录,使用更改使用权限的命令
$ sudo chomd 755 *.sh
sudo 命令可能会要求输入管理员密码。
小知识:bin 目录下存在用于启动和停止 tomcat 的许多脚本。Unix下所有需要直接调用的脚本均以 shell 脚本文件(.sh)形式提供,而 windows 系统则以批处理文件(.bat)形式提供
启动 tomcat
cd 到 tomcat 根目录下,使用如下命令即可启动和关闭
$ sudo sh startup.sh
$ sudo sh shutdown.sh
创建数据库
创建user表
创建web工程
打开 Eclipse,创建 Dynamic web project
项目。
创建 webContent/login.jsp
页面
创建 /src/me/nijun/action/login/LoginAction.java
第一步 创建login.jsp页面
<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html ng-app="LoginModule">
<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>Login</title><link rel="stylesheet" href="css/bootstrap-3.0.0/css/bootstrap.css"><script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"type="text/javascript"></script><script type="text/javascript" src="js/angular-1.3.0.js"></script><script type="text/javascript" src="js/form.js"></script>
</head>
<body>
<div class="panel panel-primary"><div class="panel-heading"><div class="panel-title">登录</div></div><div class="panel-body"><div class="row"><div class="col-md-12"><%--<form class="form-horizontal" role="form" ng-submit="submit()">--%><form class="form-horizontal" role="form" ng-controller="LoginForm"><div class="form-group"><label class="col-md-2 control-label">邮箱:</label><div class="col-md-10"><input type="email" id="email" name="email" class="form-control"placeholder="推荐使用126邮箱" ng-model="email"></div></div><div class="form-group"><label class="col-md-2 control-label">密码:</label><div class="col-md-10"><input type="password" id="password" name="password"class="form-control" placeholder="只能是数字、字母、下划线"ng-model="password"></div></div><div class="form-group"><div class="col-md-offset-2 col-md-10"><div class="checkbox"><label><input type="checkbox" ng-model="autoLogin">自动登录</label></div></div></div><div class="form-group"><div class="col-md-offset-2 col-md-10"><button class="btn btn-default" ng-click="submit()">提交</button><button class="btn btn-default" ng-click="resetInfo()">重置</button></div></div></form></div></div></div>
</div>
</body>
</html>
引入了 bootstrap 作为样式来源,并且引入 AngularJS 1 版本。
ng-app=" "
定义angularJS
的使用范围;ng-init="变量=值;变量='值'"
初始化变量的值,有多个变量时,中间用分号隔开;ng-model="变量"
定义变量名;ng-bind="变量"
绑定变量名,获取该变量的数据。这里的变量就是第3条的变量名。但是一般都用双重花括号来获取变量的值,比如:{{变量}}。ng-model
是用于表单元素的,支持双向绑定。对普通元素无效;ng-bind
用于普通元素,不能用于表单元素,应用程序单向地渲染数据到元素;- 当
ng-bind
和{ { } }
同时使用时,ng-bind
绑定的值覆盖该元素的内容。
具体请参见官方文档。
第二步 提交表单信息到servlet
创建模块
var loginModule = angular.module('LoginModule', []);
添加控制器
loginModule.controller('LoginForm', ["$scope","$http",func]);
func函数
function func($scope,$http) {//初始化表单信息$scope.email = "nijun717@gmail.com",$scope.password = "123456",$scope.autoLogin = false//重置表单函数$scope.resetInfo = function(){$scope.email = "",$scope.password = "",$scope.autoLogin = false},//提交表单函数$scope.submit = function(){var postData = {email:$scope.email,password:$scope.password,autoLogin:$scope.autoLogin};// $http请求servlet...}}
其中 $scope.submit
函数在 jsp
中的提交按钮 ng-click="submit()"
中被调用。最为关键的使用 $http
请求 servlet
代码如下:
//方式一
$http({method : 'POST',url : 'loginAction.do',data : $.param(postData), // pass in data as stringsheaders : { 'Content-Type': 'application/x-www-form-urlencoded' } // set the headers so angular passing info as form data (not request payload)
}).then(function(response){console.log(response.config);//请求信息console.log(response.config.data);//请求字段console.log(response.data.code);if (response.data.code == 0){window.location.href = "/success.jsp";}
},function(response){});//方式二
$http({method : 'POST',url : 'loginAction.do',data : $.param(postData), // pass in data as stringsheaders : { 'Content-Type': 'application/x-www-form-urlencoded' }
}).success(function(data){console.log(data);if (data.code == 0){window.location.href="/success.jsp";}
});
注意,这里有一个坑,当我们在页面中使用 ajax 来异步调用 controller (这里就是servlet)时,这时候页面跳转的函数就不会生效了。包括 forward() 和 sendRedirect() 两个方法。而且我们想要跳转的页面会被当做返回值来返回。这个问题怎么解决呢?
其实 ajax 在调用 controller 之后会自动返回到上面代码方式二
的 success 函数位置,因此,若我们直接在 controller 中进行页面跳转,则目标页面的源代码会被返回到这个 success 函数里,正确的页面跳转方式应该是在 success 函数中完成,如上面代码中的:
window.location.href="anotherAction.do";
//这行代码中的href值是另一个controller的名字,通过另一个controller跳转到另一个页面。当然也可以直接使用 html 或者 jsp 页面
为此,我总结一下:$http 是 ajax 的封装,是用来与服务器交互获取 json 数据的,其实就是异步调用,因此在服务器不能直接进行页面的跳转与转发,服务器处理表单数据后将所需的 json 信息返回给客户端中的 success 函数,我们在这个函数里再处理是否要进行页面跳转。
第三步 创建 Controller
创建 LoginAction.java
继承 HttpServlet
,然后在 web.xml
中配置servlet和servlet映射的URL路径。web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"version="3.1"><display-name>SimpleWebDemo</display-name><welcome-file-list><welcome-file>login.jsp</welcome-file></welcome-file-list><servlet><servlet-name>LoginAction</servlet-name><servlet-class>me.nijun.action.login.LoginAction</servlet-class></servlet><servlet-mapping><servlet-name>LoginAction</servlet-name><url-pattern>/loginAction.do</url-pattern></servlet-mapping>
</web-app>
覆盖HttpServlet中的doPost()和doGet()方法,一般在doPost()中调用doGet()方法。
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {System.out.println("servlet doPost.");doGet(request,response);String email = (String) request.getParameter("email");String password = (String) request.getParameter("password");PrintWriter writer = response.getWriter();JSONObject jsonObject = new JSONObject();if (EMAIL.equals(email) && PASSWORD.equals(password)) {jsonObject.put("code", 0);} else {jsonObject.put("code", 1);}writer.print(jsonObject);writer.flush();writer.close();
}
第四步 访问数据库
使用传统的JDBC方式来访问数据库,首先导入 mysql-connector-java-5.0.8-bin.jar
连接mysql的核心jar包。
编写实体类
package me.nijun.domain;/*** Created by nimon on 2017/7/13.*/
public class User {private int id;private String email;private String password;public User(){}public User(String email, String password) {this.email = email;this.password = password;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getEmail() {return email;}public void setEmail(String email) {this.email = email;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}
}
连接的获取和释放
采用单例模式,driver、url的格式可以参考 xxxx。
/*** Created by nimon on 2017/7/13.* 实现了单例模式的JDBC连接数据库的工具类.*/
public final class JDBCUtilSingleton {static String driver = "com.mysql.jdbc.Driver";String url = "jdbc:mysql://localhost:3306/smartni";String username = "root";String password = "123";Connection connection = null;private static JDBCUtilSingleton instance = null;//私有构造public JDBCUtilSingleton() {}//并发 加锁public static JDBCUtilSingleton getInstance() {if (instance == null) {synchronized (JDBCUtilSingleton.class) {if (instance == null) {instance = new JDBCUtilSingleton();}}}return instance;}//加载JVM时只创建一次连接static {try {Class.forName(driver);} catch (ClassNotFoundException e) {e.printStackTrace();}}//获取连接public Connection getConnection() throws SQLException {return (Connection) DriverManager.getConnection(url, username, password);}//规范释放资源方法public void Free(ResultSet rs, Statement stmt, Connection conn){try{if(rs != null){rs.close();}} catch (SQLException e) {e.printStackTrace();}finally {try{if(stmt != null){stmt.close();}} catch (SQLException e) {e.printStackTrace();}finally {try{if(conn != null){conn.close();}} catch (SQLException e) {e.printStackTrace();}}}}
}
定义dao接口
UserDao.java
public interface UserDao {/*** 添加一个用户* @param user 需要添加到数据库的用户对象* @return 影响的行数* @throws DaoException*/public int addUser(User user) throws DaoException;/*** 得到一个用户* @param username 得到用户所需要的用户名字段* @return 得到的用户对象* @throws DaoException*/public User findUser(String username) throws DaoException;}
实现dao接口的实现类
UserDaoImpl.java
public class UserDaoImpl implements UserDao {JDBCUtilSingleton instance = JDBCUtilSingleton.getInstance();@Overridepublic int addUser(User user) throws DaoException {Connection conn = null;PreparedStatement stmt = null;ResultSet set = null;int res = 0;try {conn = instance.getConnection();//防止sql注入String sql = "insert into user values(null,? ,? ,?)";stmt = conn.prepareStatement(sql);//设置不自动提交conn.setAutoCommit(false);stmt.setString(1, user.getUsername());stmt.setString(2, user.getEmail());stmt.setString(3, user.getPassword());res = stmt.executeUpdate();System.out.println("插入记录数: " + res + "条.");conn.setAutoCommit(true);return res;} catch (SQLException e) {throw new DaoException(e.getMessage(), e);} finally {instance.Free(set,stmt,conn);return res;}}@Overridepublic User findUser(String username) throws DaoException {Connection conn = null;PreparedStatement stmt = null;ResultSet set = null;User user = new User();try {conn = instance.getConnection();String sql = "select id,username,email,password from user where username = ?";stmt = conn.prepareStatement(sql);stmt.setString(1, username);set = stmt.executeQuery();//将指针移动到第一条记录之后if (set.next()) {user.setId(set.getInt(1));user.setUsername(set.getString(2));user.setEmail(set.getString(3));user.setPassword(set.getString(4));}} catch (SQLException e) {throw new DaoException(e.getMessage(), e);} finally {instance.Free(set,stmt,conn);}return user;}}
PreparedStatement.executeQuery();
执行完成之后获得的 ResultSet
对象, ResultSet
是一个接口,¢在获取内容时需要先调用 next()
方法,将读取的指针移动到需要读取的记录的后面,这样才可以获取到数据,这有点类似于LinkedList中的Iterator迭代器。最近也在重新复习这块,以后整理一篇Java集合框架的笔记。
测试 Dao
UserDaoImplTest.java
public class UserDaoImplTest {UserDao ud = new UserDaoImpl();@Testpublic void addUser() throws Exception {User user = new User();user.setUsername("SmartNi");user.setEmail("nijun717@gmail.com");user.setPassword("123456");ud.addUser(user);}@Testpublic void findUser() throws Exception {User user = ud.findUser("SmartNi");System.out.println(user);}@Testpublic void testSplit() {String text = "f:/jsp:sad";String[] split = text.split(":");for (String s : split){System.out.println(s);}}
}
自定义异常,继承 RuntimeException ,具体操作由父类实现。
public class DaoException extends Exception {public DaoException() {}public DaoException(String message) {super(message);}public DaoException(String message, Throwable cause) {super(message, cause);}public DaoException(Throwable cause){super(cause);}
}
定义Service接口
UserService.java
public interface UserService {/*** 获取用户名对应的用户对象* @param username 得到用户所需要的用户名字段* @return 得到的用户对象* @throws DaoException*/public User login(String username) throws ServiceException;/*** 添加用户的服务* @param user 需要添加到数据库的用户对象* @return 影响的行数* @throws ServiceException*/public int add(User user) throws ServiceException;
}
实现 Service 接口
UserServiceImpl.java
public class UserServiceImpl implements UserService {UserDao ud = new UserDaoImpl();@Overridepublic User login(String username) throws ServiceException {try {return ud.findUser(username);} catch (DaoException e) {e.printStackTrace();throw new ServiceException(e.getMessage(), e);}}@Overridepublic int add(User user) throws ServiceException {try {return ud.addUser(user);} catch (DaoException e) {e.printStackTrace();throw new ServiceException(e.getMessage(), e);}}
}
有个想法
因为,这个例子中我用了 AngularJS ,使用到了 $http 异步来发送表单提交请求,页面的跳转必须还得由客户端根据服务端传来的信息做判断再进场跳转。
还有一点,我这里将登录的逻辑放在了doPost()中,但是 UserAction
类将来必定不只是处理登录操作,还有登出、注册等等操作,不可能将所有操作都放在 doPost()
方法中,所以我的解决办法是:
- 每个请求操作对应一个方法。
- 根据客户端传递过来的 method 字段判断调用哪个方法。
我们来看看改进后的 doPost()
@Overridepublic void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {System.out.println("servlet doPost.");doGet(request,response);String method = request.getParameter("method");//判断请求的是什么方法if("login".equals(method)){login(request,response);}//...未来有更多的方法}
但是,有没有发现,我们每新增一个方法,就需要手动在这里多写一个判断语句。运用反射机制就可以解决这个问题。
BaseAction.java
/*** Created by nimon on 2017/7/14.* 功能: 执行指定方法, 方便跳转页面*/
public class BaseAction extends HttpServlet {/**** @param req* @param resp* @throws ServletException* @throws IOException*/@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {super.service(req, resp);/*得到方法名*/String methodName = req.getParameter("method");System.out.println("BaAction : 方法名 : " + methodName);if (methodName == null || methodName.trim().isEmpty()) {throw new RuntimeException("您没有传递需要调用的method方法参数,没有调用方法.");}/*通过反射得到方法*/Class c = this.getClass();Method method = null;try {method = c.getMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);} catch (NoSuchMethodException e) {e.printStackTrace();throw new RuntimeException("没有找到你需要调用的方法.");}/*调用method表示的方法*/try {String result = (String) method.invoke(this, req, resp);/*如果用户返回 null 或者返回空字符串,就什么也不做.*/if (result == null || result.trim().isEmpty()) {return;}/*1. 约定返回的字符串中没有包含 ":" ,就说明是转发操作.2. 如果包含 ":" ,分为下面两种情况:1). 前缀 f 表示转发.2). 前缀 r 表示重定向.*/if (result.contains(":")) {String[] split = result.split(":");if (split[0].equalsIgnoreCase("r")) {req.getRequestDispatcher(split[1]).forward(req, resp);} else if (split[0].equalsIgnoreCase("f")) {resp.sendRedirect(split[1]);} else {throw new RuntimeException("您请求的地址,当前还不支持.");}}else{req.getRequestDispatcher(result).forward(req, resp);}} catch (Exception e) {e.printStackTrace();System.out.println("您调用的方法--" + methodName + "--它内部抛出了异常.");throw new RuntimeException();}}
}
只要让其他 Servlet
继承这个 BaseAction
,然后在自定义方法中返回约定的字符串,即可实现页面跳转。其实这个想法是根据 Strust2 的设计思路来实现的。
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 双眼皮手术过程
...
2024/4/20 19:35:34 - vue入门
1. Vue.js 1.1. Vue.js是什么? 1). 作用: 动态构建用户界面 2). 特点:* 遵循MVVM模式* 编码简洁, 体积小, 运行效率高, 移动/PC端开发* 它本身只关注UI, 可以轻松引入vue插件和其它第三库开发项目 3). 与其它框架的关联:* 借鉴angular的模板和数据绑定技术* 借鉴react的组件…...
2024/4/30 18:04:33 - 内双怎么贴双眼皮是割还是埋线
...
2024/4/30 18:12:37 - 割双眼皮要花多少钱
...
2024/4/20 19:35:41 - 使用Spring Boot和Gradle创建AngularJS项目
Spring Boot 是由 Pivotal 团队提供的全新框架,其设计目的是用来简化新 Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。 本文主要是记录使用 Spring Boot 和 Gradle 创建项目的过程&am…...
2024/4/30 11:48:59 - 单眼皮变双眼皮方法
...
2024/4/26 16:01:07 - AngularJS介绍
AngularJS介绍–AngularJS的前世今生 AngularJS是什么 在Web开发领域,我们一般使用HTML作为前端页面元素的声明式语言,使用CSS技术作为展示样式的描述语言,JavaScript作为业务处理交互的命令式语言。当我们构建非常复杂的Web应用时࿰…...
2024/4/30 18:31:05 - 深圳割做双眼皮哪家好
...
2024/4/30 17:55:47 - Spring Boot gradle
最近有写一个电子订单商务网站,使用JAVA8,SPRING,ANGULARJS对项目使用的技术和大家分享。 第一次写博客,哪有不对需要改正的请联系改正。 因为是项目是我给别人做的无法提供源码见谅,我尽最大努力让大家能看懂。 首先从项目的构建开始&#x…...
2024/4/30 6:59:40 - 韩式双眼皮多少钱
...
2024/4/20 5:58:11 - 双眼皮微创
...
2024/4/20 19:36:07 - angular-cli 无法启动项目
2019独角兽企业重金招聘Python工程师标准>>> 全局安装的angular-cli 和项目安装的angular-cli版本一致,才可以使用ng serve 否则只能用npm strat启动 转载于:https://my.oschina.net/u/3261598/blog/1551505...
2024/4/30 18:13:56 - 整容双眼皮多少钱
...
2024/4/25 5:58:34 - Angular(一)——使用angular-cli创建新项目
1,安装 cnpm install -g angular/cli 2,创建 ng new ng-project 3,安装依赖 cd ng-project cnpm install 4,启动 ng serve --open 5,更名 我尝试改变项目名称,把package.json里的name改掉,又把文…...
2024/4/20 4:12:30 - 单眼皮自然变韩式微创双眼皮多少钱
...
2024/4/30 17:47:57 - angular-cli 安装与使用
安装Angular CLI 1.首先确认安装了node.js和npm // 显示当前node和npm版本 $ node -v $ npm -v // node 版本高于6.9.3 npm版本高于3.0.0 2.全局安装typescript(可选) $ npm install -g typescript // 新建项目的时候会自动安装typescript(非全局)所以…...
2024/4/20 19:35:59 - 如何下载Angular-Cli并下载运行项目
1、安装angular/cli npm install -g angular/cli2、创建项目 ng new hum3、切换路径 cd hum4、运行项目 ng serve --open5、查看项目http://localhost:4200/...
2024/4/20 19:36:05 - 切割割双眼皮一般多少钱
...
2024/4/20 19:36:05 - Angular-cli 搭建项目
一、首先需要安装node和npm 查看你的node以及npm版本: node -v 查看node版本 npm -v 查看npm版本 要求所有版本都是最新的,不然可能会出错。 设置淘宝镜像,这样下载东西就是从国内网站下载了,网速更快 npm configset registry htt…...
2024/4/20 19:36:03 - angular-cli中组件创建和使用
angular的组件创建和vue、react不太一样,它是使用命令去创建,操作如下: 第一步:创建组件 在命令行输入: ng g component 组件名 比如 ng g component my 新生成的组件,在src的app里面的文件夹 my 里 在 src/app/ap…...
2024/4/20 19:36:02
最新文章
- 网络安全漏洞分析之远程代码执行
介绍 Apache Flume 是一个分布式的,可靠的,并且可用于高效地收集,汇总和移动大量日志数据的软件。它具有基于流数据流的简单而灵活的体系结构。它具有可调的可靠性机制以及许多故障转移和恢复机制,并且具有健壮性和容错性。它使用…...
2024/4/30 19:15:49 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - vue中内置指令v-model的作用和常见使用方法介绍以及在自定义组件上支持
文章目录 一、v-model是什么二、什么是语法糖三、v-model常见的用法1、对于输入框(input):2、对于复选框(checkbox):3、对于选择框(select):4、对于组件(comp…...
2024/4/29 17:32:21 - 理解 Golang 变量在内存分配中的规则
为什么有些变量在堆中分配、有些却在栈中分配? 我们先看来栈和堆的特点: 简单总结就是: 栈:函数局部变量,小数据 堆:大的局部变量,函数内部产生逃逸的变量,动态分配的数据&#x…...
2024/4/30 2:57:27 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/4/29 23:16:47 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/4/30 18:14:14 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/4/29 2:29:43 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/4/30 18:21:48 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/4/27 17:58:04 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/4/27 14:22:49 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/4/28 1:28:33 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/4/30 9:43:09 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/4/27 17:59:30 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/4/25 18:39:16 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/4/28 1:34:08 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/4/26 19:03:37 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/4/29 20:46:55 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/4/25 18:39:14 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/4/26 23:04:58 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/4/27 23:24:42 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/4/28 5:48:52 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/4/30 9:42:22 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/4/30 9:43:22 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/4/30 9:42:49 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57