本文最初发布在Okta开发人员博客上 。 感谢您支持使SitePoint成为可能的合作伙伴。

Electron是一个框架,可使用JavaScript,HTML和CSS等Web技术构建跨平台的桌面应用程序。 它是为GitHub的Atom编辑器创建的,此后得到了广泛的采用。 电子为我每天使用的多个应用程序提供动力:Slack,Kitematic和Visual Studio Code等。

Electron 2.0于2018年5月上旬发布,并对项目进行了更改以遵守严格的语义版本控制。 这对开发人员来说是个好消息,因为这意味着修补程序版本将更加稳定,并且新功能将仅在主要版本中提供。 当开放源代码项目正确使用语义版本控制时,最终用户不会经常看到破坏性的更改,并且往往会提高工作效率。

Electron 3.0于2018年9月18日发布,包含主要版本的颠簸和一些新功能。 有关更多信息,请参见Electron博客 。

使用Web技术开发桌面应用程序是一个吸引人的概念。 我认为Gerard Sans的这则推文很钉钉:

你有网页开发技能吗? 大! 您具有使用Electron构建桌面应用程序所需的条件!

在本文中,我将向您展示如何使用TypeScript,AppAuth-JS和OpenID Connect(OIDC)创建Electron应用程序。 您将学习如何为用户添加身份验证和保护Electron应用程序。

什么是AppAuth?

AppAuth是一个旨在为本机应用程序创建客户端SDK的项目。 使用OIDC和OAuth 2.0,可以在您的应用中实现身份验证和授权。 它具有可用于iOS,macOS,Android和JavaScript环境的SDK。 AppAuth-JS是JavaScript客户端的SDK。 AppAuth还支持OAuth的PKCE扩展 ,以使公共客户端更加安全。

几乎每个应用程序都依赖于安全的身份管理系统。 对于正在构建Electron应用程序的大多数开发人员,在滚动自己的身份验证/授权或插入托管身份服务(如Okta)之间都需要做出决定。

使用Electron构建桌面应用

我将为您简化事情。 您将使用现有示例,而不是从头开始构建应用程序。 AppAuth-JS项目有两个示例,一个服务器端示例,其节点位于src / node_app / index.ts ,一个appauth-js-electron-sample 。 克隆电子示例开始。

git clone https://github.com/googlesamples/appauth-js-electron-sample.git okta-electron-example

在此项目中打开package.json并进行以下更改。

"scripts": {"compile": "tsc","watch": "tsc --watch","start": "npm run compile && npx electron .","dev": "npm run compile && npm run watch & npx electron ."},"files": ["built/**""author": "rahulrav","license": "MIT","dependencies": {"@openid/appauth": "^1.1.1","@types/react": "^16.3.17","@types/react-dom": "^16.0.6","material-design-lite": "^1.3.0"},"devDependencies": {"electron": "^3.0.0","typescript": "^2.9.1"}}

这些更改不是必需的,但它们会使事情变得更容易。 “脚本”中的更改使得它可以在运行npm run devnpm start之前进行编译。 您还需要将electron依赖关系变为devDependency并将TypeScript升级到最新版本。

导航到克隆目录,使用npm安装依赖项,然后运行该应用程序。

cd okta-electron-example
npm i
npm run dev

它应该启动该应用程序并显示一个登录链接。

initial-load.png

如果您拥有Google帐户,请点击登录 ,然后登录 ,您将被重定向回您的应用程序。 您应该会看到您的头像和名称。

Google登录后

下图显示了如何使用OpenID Connect进行此授权流程。

OIDC流程

此时,您可以看到正在通过Google进行身份验证。 在下一节中,我将向您展示如何添加PKCE支持以使该应用程序更安全,以及如何使用Okta代替Google。

为什么要使用Okta进行身份验证?

您可能会问:当使用Google身份验证时,为什么我应该使用Okta? 原因很简单。 如果您想管理应用程序的用户(并且不可避免),Okta可以实现。 使用Google,拥有Google帐户的任何人都可以登录,但是您无法撤消访问权限或更新用户的权限,因为您无法通过Google管理用户。 Okta使您可以管理用户,以及修改其属性和权限。 更好的是,您仍然可以使用Okta将Google用作社交登录机制!

在桌面应用程序中使用Okta与OIDC进行身份验证

Okta的目标是使身份管理比以往更加轻松,安全和可伸缩。 Okta是一项云服务,允许开发人员创建,编辑和安全地存储用户帐户和用户帐户数据,并将它们与一个或多个应用程序连接。 我们的API使您能够:

  • 验证和授权您的用户
  • 存储有关您的用户的数据
  • 执行基于密码的社交登录
  • 通过多因素身份验证保护您的应用程序
  • 以及更多! 查看我们的产品文档

你准备好了吗? 立即注册一个永久免费的开发者帐户 ! 完成后,请完成以下步骤以创建本机OIDC应用程序。

  1. 登录到您在developer.okta.com上的开发者帐户。
  2. 导航到“ 应用程序” ,然后单击“ 添加应用程序”
  3. 选择本 ,然后单击下一步
  4. 为应用程序命名(例如My Electron App ),然后添加http://localhost:8000作为登录重定向URI。
  5. 对于允许的授予类型,除了授权代码外,选择刷新令牌
  6. 单击完成

现在,您可以使用应用程序设置将使用Google更改为Okta。 修改flow.ts以使用Okta应用程序的设置。

const openIdConnectUrl = 'https://{yourOktaDomain}/oauth2/default';
const clientId = '{yourClientId}';
const redirectUri = 'http://localhost:8000';

您还需要更新app.ts以使用应用程序的/userinfo端点。

let request =new Request('https://{yourOktaDomain}/oauth2/default/v1/userinfo', {headers: new Headers({'Authorization': `Bearer ${accessToken}`}),method: 'GET',cache: 'no-cache'});

如果您重新启动应用程序并尝试登录,它将失败,因为您没有使用PKCE。 在启动的浏览器的地址栏中,您会看到类似以下的错误。

error=invalid_request&error_description=PKCE+code+challenge+is+required+when+the+token+endpoint+authentication+method+is+%27NONE%27.

将PKCE支持添加到您的桌面应用程序

PKCE(发音为“ pixy”)是OAuth 2.0的安全扩展,适用于移动(和桌面)客户端上的公共客户端。 它旨在防止在同一设备上运行的恶意应用程序拦截授权代码。

    +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~+| End Device (e.g., Smartphone)  ||                                || +-------------+   +----------+ | (6) Access Token  +----------+| |Legitimate   |   | Malicious|<--------------------|          || |OAuth 2.0 App|   | App      |-------------------->|          || +-------------+   +----------+ | (5) Authorization |          ||        |    ^          ^       |        Grant      |          ||        |     \         |       |                   |          ||        |      \   (4)  |       |                   |          ||    (1) |       \  Authz|       |                   |          ||   Authz|        \ Code |       |                   |  Authz   || Request|         \     |       |                   |  Server  ||        |          \    |       |                   |          ||        |           \   |       |                   |          ||        v            \  |       |                   |          || +----------------------------+ |                   |          || |                            | | (3) Authz Code    |          || |     Operating System/      |<--------------------|          || |         Browser            |-------------------->|          || |                            | | (2) Authz Request |          || +----------------------------+ |                   +----------++~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~+

PKCE工作组提供了一个很好的解释,我在下面进行了介绍。 您可以在官方RFC中阅读更多内容。

“为减轻这种攻击,PKCE使用了动态创建的密码随机密钥,称为“代码验证器”。 为每个授权请求创建一个唯一的代码验证器,并将其转换后的值(称为“代码挑战”)发送到授权服务器以获取授权代码。 然后,将获得的授权代码与“代码验证者”一起发送到令牌端点,服务器将其与先前接收的请求代码进行比较,以便它可以执行客户端对“代码验证者”的拥有证明。 这是缓解措施,因为攻击者不知道此一次性密钥,因为它是通过TLS发送的并且无法被截获。”

下图显示了PKCE如何与您的应用程序和Okta一起使用。

PKCE的验证码流

现在,您将PKCE添加到您的Electron应用程序中! 在flow.ts ,为PKCE添加一个challengePair变量作为AuthFlow类的成员变量。

private challengePair: { verifier: string, challenge: string };

在构造函数的末尾添加一行以初始化此变量。

this.challengePair = AuthService.getPKCEChallengePair();

创建pkce.ts来定义AuthService类。

const crypto = require('crypto');export class AuthService {static getPKCEChallengePair() {let verifier = AuthService.base64URLEncode(crypto.randomBytes(32));let challenge = AuthService.base64URLEncode(AuthService.sha256(verifier));return {verifier, challenge};}static base64URLEncode(str: Buffer) {return str.toString('base64').replace(/\+/g, '-').replace(/\//g, '_').replace(/=/g, '');}static sha256(buffer: string) : Buffer {return crypto.createHash('sha256').update(buffer).digest();}
}

将此类的导入添加到flow.ts

import { AuthService } from './pkce';

makeAuthorizationRequest()方法中,在if (username) {}逻辑之后,将代码质询和方法添加到extras映射中。

// PKCE
extras['code_challenge'] = this.challengePair.challenge;
extras['code_challenge_method'] = 'S256';

makeRequestTokenRequest() ,添加一个tokenRequestExtras变量并将其发送到请求中。

let tokenRequestExtras = { code_verifier: this.challengePair.verifier };// use the code to make the token request.
let request = new TokenRequest(clientId,redirectUri,GRANT_TYPE_AUTHORIZATION_CODE,code,undefined,tokenRequestExtras
);

进行这些更改之后,您应该可以登录。但是,当您单击USER INFO时 ,您将看不到用户的名称或头像。 通过查看 > 切换开发者工具打开Chrome开发者工具以了解原因。

Electron的开发人员工具

要解决此问题,请在flow.ts中将scope变量flow.ts为包括profile 。 在使用时,请添加offline_access以便您的应用无需互联网即可正常运行。

const scope = 'openid profile offline_access';

刷新您的应用程序(在Mac上为Command + R,在Windows / Linux上为Ctrl + R),现在单击USER INFO时应会看到名称。

来自用户信息端点的名称

注意:我利用这些PKCE代码示例来完成所有这些工作。

在Okta中添加头像

您可能会注意到,用户信息端点未返回化身。 app.ts的代码根据picture属性设置头像。

private updateUi() {this.handleSignIn.textContent = SIGN_OUT;this.fetchUserInfo.style.display = '';if (this.userInfo) {this.userProfileImage.src = `${this.userInfo.picture}?sz=96`;this.userName.textContent = this.userInfo.name;this.showSnackBar({message: `Welcome ${this.userInfo.name}`, timeout: 4000});this.userCard.style.display = '';}
}

您可以在上面的代码中删除?sz=96 ,因为此示例未使用它。

要向您的用户添加picture属性,请登录Okta仪表板,然后导航至Users > Profile Editor 。 单击第一个“用户”并添加picture属性。 点击保存

添加图片属性

浏览回到配置文件编辑器,然后为您的Electron App单击映射 。 创建从user.picturepicture的映射,然后选择将映射应用于用户创建和更新。 单击“ 保存映射立即应用更新”

添加图片映射

现在转到“ 用户” >“ 人员” ,选择一个用户,导航至“ 个人资料”标签,然后点击“ 编辑” 。 在底部添加picture的值。 例如,您可以使用我们的Okta Developer徽标的URL。

https://www.okta.com/sites/all/themes/Okta/images/logos/developer/Dev_Logo-02_Large.png

现在,如果您单击用户信息链接,则应该看到与您的用户关联的头像。

用户信息图片

提示:如果要在生产中使用此图像,建议您为图片使用较小的图像(例如150×150尺寸)。 您还可以对图像进行base64编码 ,并将其值用于图片。

下面的屏幕截图显示了此应用,并为我的帐户添加了一些额外的修饰和base64图像值。

抛光哑光

打包您的桌面应用以进行生产

要将此应用打包以进行生产发行,可以使用electronic-builder 。 使用npm安装电子生成器。

npm i -D electron-builder@20.28.4

在您的package.json添加一个build部分:

"build": {"appId": "com.okta.developer.electron","productName": "Electron Awesomeness","mac": {"category": "public.app-category.developer-tools"}
}

然后添加packdistpostinstall脚本。

"scripts": {..."pack": "npm run compile && electron-builder --dir","dist": "npm run compile && electron-builder","postinstall": "electron-builder install-app-deps"
}

要将您的应用打包以进行生产,请使用以下命令:

  • npm run pack会生成package目录,而不会真正打包它。 这对于测试目的很有用。
  • npm run dist将以可分发格式打包(例如dmg,Windows安装程序,deb软件包)。

注意:如果应用程序在打包后仍未启动,则可能是因为您未配置代码签名 。 要在构建macOS时禁用代码签名,请运行export CSC_IDENTITY_AUTO_DISCOVERY=false 。 如果您拥有Apple开发者帐户,请打开Xcode,转到“首选项” >“ 帐户”并确保您已登录,并下载了开发证书。

电子示例应用程序源代码

您可以在此处找到本文的源代码。

我做了一些小的调整(例如,优化导入,将双引号更改为单引号),但是没有什么大的调整。 要查看该项目与原始项目之间的区别, 请单击此处 。

了解有关Electron,AppAuth和OIDC的更多信息

你有它! 继续并使用您的网络技能来创建出色的桌面应用程序!

要了解有关Electron,AppAuth,React和OIDC的更多信息,请查看以下资源:

  • 编写您的第一个电子应用程序
  • 使用Kotlin在Android中构建基本的CRUD应用
  • 使用React,GraphQL和用户身份验证构建运行状况跟踪应用
  • 身份,声明和令牌– OpenID Connect入门,第1部分,共3部分

有问题吗? 请在下面发表评论, 在Twitter上对我进行ping操作 ,或在我们的开发者论坛上提问。

喜欢在这里学到的东西吗? 关注@oktadev , 在Facebook上像我们一样, 在LinkedIn 上关注我们,或在YouTube上观看我们的视频 。

变更日志:

  • 2018年9月19日:更新为使用Electron 3.0.0和AppAuth 1.1.1。 请参阅okta-appauth-js-electron-example#1中的示例应用程序更改; 可以在okta.github.io#2327中查看对此职位的更改。

From: https://www.sitepoint.com/use-your-web-dev-skills-to-build-a-desktop-app-with-electron/

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

相关文章

  1. 【有趣JS连载】使用 JS 操作 HTML 元素(第9章)

    文档对象模型(DOM)JS 有很多地方让咱们吐槽,但没那么糟糕。作为一种在浏览器中运行的脚本语言,它对于处理web页面非常有用。在本中,我们将看到我们有哪些方法来交互和修改HTML文档及其元素。但首先让我们来揭开文档对象模型的神秘面纱。文档对…...

    2024/4/30 19:53:40
  2. 使用 JS 操作 HTML 元素

    文档对象模型(DOM) JS 有很多地方让咱们吐槽,但没那么糟糕。作为一种在浏览器中运行的脚本语言,它对于处理web页面非常有用。在本中,我们将看到我们有哪些方法来交互和修改HTML文档及其元素。但首先让我们来揭开文档对象模型的神秘面纱。 文…...

    2024/5/1 1:15:12
  3. web前端开发与iOS终端开发的异同[转]

    Untitled Note http://blog.cnbang.net/tech/2495/ web前端开发与iOS终端开发的异同2014-12-22毕业之前一直在做前端开发,毕业后就转成做iOS开发,这两者有很多挺有意思的对比,尝试写下我能想到的它们的一些相同点和不同点。语言前端和终端作为…...

    2024/4/30 21:16:52
  4. 前端基础知识整理汇总(下)

    接上前面两期的内容,《前端基础知识整理汇总(上)》、《前端基础知识整理汇总(中)》,如果你还没有看前面内容的话,建议你可以点开连接看看,也可以收藏着有空的时候,慢慢看…...

    2024/4/30 17:26:07
  5. Web前端开发与iOS终端开发的异同

    百度知道看到的一篇文章,比较认可,转载至此. 原文链接 语言 前端和终端作为面向用户端的程序,有个共同特点:需要依赖用户机器的运行环境,所以开发语言基本上是没有选择的,不像后台想用什么就用什么,iOS只能用Objectiv…...

    2024/4/30 19:30:15
  6. 割双眼皮有多疼

    ...

    2024/4/30 17:46:16
  7. 割双眼皮之前医生会设计吗

    ...

    2024/5/1 0:23:33
  8. 为什么一生病就是割割完双眼皮眼睛流泪就刺痛

    ...

    2024/4/30 17:04:44
  9. 双眼皮术后一周眨眼疼

    ...

    2024/4/30 16:23:40
  10. 割双眼皮流脓

    ...

    2024/4/28 21:00:08
  11. 经常贴双眼皮会变双吗

    ...

    2024/4/30 6:57:16
  12. 双眼皮割太宽折不进去

    ...

    2024/4/30 23:34:25
  13. 平行黄寺割开双眼皮图片

    ...

    2024/4/30 21:50:22
  14. 沈阳协和修复外双眼皮 加开内眼角恢复

    ...

    2024/4/21 15:55:25
  15. 埋线双眼皮伤口有多大

    ...

    2024/4/20 14:45:05
  16. 自定义jinja2 过滤器

    今天,我们要讲的是自定义jinja2 过滤器这个知识点,因为官方文档对此一代而过,讲得不够清楚,所以我们专门拿出来讲一下。 例子 例子写了两个自定义过滤器,一个是转换字典到字符串的过滤器,一个是返回当前参数…...

    2024/4/20 14:45:03
  17. AngularJS -自定义过滤器

    发现我们所使用的都是Angular已经封装好的过滤器,现在,自己定义过滤器比自带的用起来更加的心应手,下面,我分享下我在使用自定义过滤器的心得吧 自定义过滤器 1、过滤器中,直接return function(value) {},…...

    2024/4/21 23:10:47
  18. ionic3自定义管道

    1、ionic start demo tabs,创建项目 2、ionic g pipe change-text, 创建一个管道,创建成功后目录中会多一个pipe目录,如图: 3、我们做一个改变字符串的管道,相当于ng1中的过滤,需要在app.module.ts中引入: app.module.ts: import { NgModule, ErrorHan…...

    2024/4/20 14:45:00
  19. 长沙割双眼皮美 莱名

    ...

    2024/4/20 14:44:59
  20. 先做双眼皮还是先纹眉

    ...

    2024/4/20 14:44:59

最新文章

  1. 架设WebSocket的最后一环,如何设置好nginx反向代理

    WebScoket都已经完工快一个月,经过一段时间的测试,公司还是准备把服务器换到鹅厂,用EO来解决CDN内容分发和DDOS防护问题,由于EO并不支持URL 路径转发,只支持转发到一个站点的80或则443端口,如果想做路径分发…...

    2024/5/1 2:04:12
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 安卓java打包uniapp原生插件 和 uniapp使用安卓android原生插件

    1.uniapp dcloud官方文档 简介 | uni小程序SDK 2.前提,需要有经验的安卓java开发人员,并且同时具备uniapp移动端开发经验。说明:android打包的.aar和uniapp需要的.aar是不一样的,uniapp需要的.aar是需要有一些特定配置的&#x…...

    2024/4/30 0:27:49
  4. 谷粒商城实战(008 缓存)

    Java项目《谷粒商城》架构师级Java项目实战,对标阿里P6-P7,全网最强 总时长 104:45:00 共408P 此文章包含第151p-第p157的内容 简介 数据库承担落盘(持久化)工作 拿map做缓存 这种是本地缓存,会有一些问题 分布…...

    2024/4/30 3:45:22
  5. __dirname 在ES模块中的使用

    前言 ECMAScript模块是 JavaScript 的新标准格式。在Node.js中越来越多的库逐渐从从CommonJS转移到ES模块 注:这里是指“真”ES 模块并不是指代码中 Node.js 中使用 import 写法但是实际被 tsc 转成 commonJS 的形式 但是Node.js ES 开发中此前有一个棘手的问题是获…...

    2024/4/30 2:01:48
  6. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/4/29 23:16:47
  7. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/30 18:14:14
  8. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  9. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/4/30 18:21:48
  10. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  11. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  12. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  13. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  14. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  15. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  16. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  17. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  18. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  19. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  20. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/4/26 23:04:58
  21. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  22. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  23. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  24. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/4/30 9:43:22
  25. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...

    2022/11/19 21:17:18
  27. 错误使用 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
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在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