[ 跨域问题 ] 前后端以及服务端 解决跨域的各种方法
这篇文章主要介绍了跨域问题,包括其定义、产生原因及各种解决方法。原因是浏览器安全策略限制,方法有 JSONP、CORS、Domain、 postMessage、Nginx配置、.NetCore配置。
前言
什么是跨域问题?
在Web应用中,当一个网页的脚本试图去请求另一个域名下的资源时,就会遇到跨域问题。跨域问题是由浏览器的同源策略所引起的。换句话说:后端返回给浏览器的数据会被浏览器的同源策略给拦截下来。
同源策略要求资源的协议、域名和端口号都必须相同,才能确保数据的安全性。如果不满足这个条件,请求将被浏览器拒绝,从而导致跨域问题的出现。
- 同源策略: 协议号-域名-端口号 都相同的地址,浏览器才认为是同源
协议号:域名:端口号 / 路径https://192.168.31.45:8080/userhttps://192.168.31.45:8080/list
上面这个例子虽然它们的路径不一样但是协议号、域名、端口号都相同,所以它们就是同源的
跨域问题的原因?
跨域问题主要是由于浏览器的安全策略限制引起的。同源策略的目的是保护用户的隐私和数据安全,防止恶意网站获取用户的敏感信息或进行未授权的操作。 通过限制跨域请求,浏览器有效地减少了许多网络攻击的风险,例如跨站脚本攻击(XSS)和跨站请求伪造(CSRF)。
JSONP
JSONP(JSON with Padding)是一种用于解决跨域请求的技术,它利用了 <script>
标签可以跨域加载资源的特性。
下面是 JSONP 解决跨域请求的基本原理:
-
前端发起 JSONP 请求: 前端页面通过动态创建
<script>
标签,设置其src
属性为包含回调函数的 URL。通常这个 URL 是指向另一个域名下的服务器接口。 -
服务端返回数据: 服务端接收到 JSONP 请求后,会将数据包装在回调函数中返回给前端。这样前端页面就可以获得跨域请求返回的数据。
-
前端处理数据: 前端页面定义好与回调函数同名的 JavaScript 函数,当服务端返回数据时,会执行这个函数并传入返回的数据作为参数,从而实现跨域数据的获取和处理。
前端代码:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><button id="btn">获取数据</button><script>// 定义一个函数 jsonp,用于发送 JSONP 请求function jsonp(url, cb) {return new Promise((resolve, reject) => {// 创建一个 script 标签const script = document.createElement('script');// 设置 script 的 src 属性,包含了请求的 URL 和回调函数名称script.src = `${url}?cb=${cb}`; // http://localhost:3000?cb='callback'// 将 script 添加到文档中document.body.appendChild(script); // 浏览器自动请求 src 中的内容// 定义一个全局函数,用于处理返回的数据window[cb] = (data) => {resolve(data)}})}// 获取按钮元素let btn = document.getElementById('btn');// 绑定点击事件btn.addEventListener('click', () => {// 发送 JSONP 请求jsonp('http://localhost:3000', 'callback').then(res => {console.log('后端的返回结果:' + res);})})</script>
</body>
</html>
后端代码:
const Koa = require('koa');
const app = new Koa();// 定义中间件函数 main,处理请求并返回数据
const main = (ctx, next) => {console.log(ctx.query); // 输出请求参数对象 { cb: 'callback' }// 从请求参数中获取回调函数名称const cb = ctx.query.cb;// 准备要返回给前端的数据const data = '给前端的数据';// 构造带有回调函数名称的字符串,格式为 'callback("给前端的数据")'const str = `${cb}('${data}')`;// 将构造好的字符串作为响应体返回给前端ctx.body = str;
}// 将 main 中间件注册到 Koa 应用中
app.use(main);// 监听 3000 端口,启动服务器
app.listen(3000, () => {console.log('listening on port 3000');
})
优点:
- 简单易用: JSONP 实现简单,只需在前端添加一个
<script>
标签即可完成跨域请求,无需复杂的配置。 - 兼容性好: JSONP 能够兼容各种浏览器,包括早期版本的浏览器,因为它是通过动态创建
<script>
标签实现的。 - 支持跨域请求: JSONP 可以在不同域之间进行数据通信,解决了传统 AJAX 请求受同源策略限制的问题。
缺点:
- 安全性问题: JSONP 存在安全风险,因为它是通过在前端动态加载脚本来获取数据,可能会被用于注入恶意脚本,导致安全漏洞。
- 只支持 GET 请求: JSONP 只能发起 GET 请求,无法支持其他类型的 HTTP 请求,如 POST、PUT 等。
- 依赖服务端支持: JSONP 需要服务端返回数据时将其包裹在一个回调函数中,因此需要服务端提供支持,如果服务端不支持 JSONP 格式返回数据,则无法使用该方法。
CORS(跨域资源共享)
CORS是一种机制,允许服务器在响应中携带一个特殊的标头,以告知浏览器该服务器允许哪些源的网页访问其资源。 可以总结为一句话:后端通过设置响应头来告诉浏览器不要拒绝接受后端的响应。
前端代码:在用户点击按钮时,通过发送跨域请求获取服务器返回的数据,并将数据打印到浏览器的控制台
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><button id="btn">获取数据</button><script>let btn = document.getElementById('btn');btn.addEventListener('click', () => {fetch('http://localhost:3000') // 发送跨域请求到服务器.then(res => res.json()).then((res) => {console.log(res); // 打印返回的数据到控制台})})</script>
</body>
</html>
代码实现了以下功能:
- 在 HTML 中定义了一个按钮元素,id 为 "btn",用于触发发送数据请求。
- 在 JavaScript 部分,使用
fetch
函数发送 GET 请求到指定的服务器地址 "http://localhost:3000"。 - 在成功接收到服务器响应后,使用
.then
方法将响应解析为 JSON 格式。 - 在第二个
.then
方法中,处理解析后的数据,并将其输出到浏览器的控制台。
后端代码 :Node.js 服务器代码,创建了一个 HTTP 服务器,监听在端口 3000。当接收到请求时,返回一个包含 "hello cors" 消息的 JSON 数据。
const http = require('http');const server = http.createServer((req, res) => {res.writeHead(200, {// cros实现原理'Access-Control-Allow-Origin': 'http://127.0.0.1:5500' // 允许来自指定地址的跨域请求})let data = {msg: "hello cors"}res.end(JSON.stringify(data)) // 返回数据给前端页面
})server.listen(3000, () => {console.log('listening on port 3000');
})
后端代码第6行在服务端设置响应头来控制跨域访问。
常见的响应头包括:
-
Access-Control-Allow-Origin
:指定允许访问的域名。 -
例如,
Access-Control-Allow-Origin: *
表示允许所有域名访问, -
而
Access-Control-Allow-Origin:'http://127.0.0.1:5500'
表示只允许特定域名访问。 -
Access-Control-Allow-Methods
:指定允许的HTTP方法。 -
Access-Control-Allow-Headers
:指定允许的自定义请求头。
CORS支持各种类型的HTTP请求,包括GET、POST等。
Domain
我们还可以使用 Domain 方法来解决一些特定情况下的跨域访问问题。 在跨域通信时,还需要注意以下几点:
-
页面的域名必须满足 Domain 方法的限制,即二级域名相同(如 example.com)。
-
父级页面需要在设置 document.domain 之前定义需要共享的变量或对象。
-
子级页面可以通过 window.parent 来访问父级页面的属性或变量,但需要确保父级页面已经加载完成并且两者的域名设置已生效。
下面举一个简单的例子来说明 Domain 方法的用法:
假设有两个页面分别位于不同子域名下,一个是 parent.example.com,另一个是 child.example.com。我们希望这两个页面能够进行跨域通信。
在父级页面 parent.example.com/index.html 中的代码如下:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Parent Page</title>
</head>
<body><h1>Parent Page</h1><iframe src="http://child.example.com/child.html"></iframe><script>document.domain = 'example.com';var messageFromParent = 'Hello from parent page!';</script>
</body>
</html>
在子级页面 child.example.com/child.html 中的代码如下:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Child Page</title>
</head>
<body><h1>Child Page</h1><script>document.domain = 'example.com';var messageFromChild = 'Hello from child page!';// 访问父级页面定义的变量var message = window.parent.messageFromParent;console.log('Message from parent: ' + message);</script>
</body>
</html>
在这个例子中,父级页面和子级页面分别设置了相同的 document.domain 为 'example.com',以实现二级域名相同。
父级页面定义了一个名为 messageFromParent
的变量,子级页面在加载后通过 window.parent 来访问父级页面定义的变量,并打印出父级页面的消息。
通过设置相同的 document.domain,父子页面之间就可以进行跨域通信,实现数据共享和交互。
postMessage
使用 postMessage()
方法结合 <iframe>
元素可以实现跨域通信,这是一种常见的技术。通过在父窗口和嵌套的 <iframe>
之间使用 postMessage()
方法,可以安全地在不同源之间进行通信。
<iframe>
可以用于解决跨域通信的问题,其原理是利用浏览器中同源策略的限制,将不同域的内容加载到独立的 <iframe>
中,通过 postMessage 方法进行跨文档通信。
在 a.html 文件中:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><h2>a.html</h2><!-- 创建一个 iframe 元素来加载 b.html --><iframe src="http://127.0.0.1:5500/postMessage/b.html" frameborder="0" id="iframe"></iframe><script>// 向 b.html 发送数据let iframe = document.getElementById('iframe');iframe.onload = function() {// 准备要发送的数据let data = {name: 'Tom'};// 通过 postMessage 方法向 iframe 发送数据iframe.contentWindow.postMessage(JSON.stringify(data), 'http://127.0.0.1:5500');}// 监听来自 b.html 的消息window.addEventListener('message', function(e) {console.log(e.data);});</script>
</body>
</html>
在 b.html 文件中:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><h4>b.html</h4><script>// 监听来自父页面的消息window.addEventListener('message', function(e) {console.log(JSON.parse(e.data));if (e.data) {// 收到消息后延迟 2 秒发送回应给父页面setTimeout(function() {window.parent.postMessage('我接受到', 'http://127.0.0.1:5500');}, 2000);}});</script>
</body>
</html>
优点:
- 安全性: 使用
<iframe>
结合 postMessage 进行跨域通信是一种相对安全的方法,能够避免常见的跨站脚本攻击(XSS)。 - 灵活性: 可以在不同域之间传递数据,实现更丰富的交互体验,如单点登录、共享数据等。
- 适用性广泛: 跨域通信是 Web 开发中常见需求,而
<iframe>
结合 postMessage 是一种通用且有效的解决方案。
缺点:
- 复杂性: 跨域通信涉及到多个文档之间的交互,需要额外的处理和编码,增加了开发的复杂度。
- 性能开销: 使用
<iframe>
进行跨域通信可能会引入额外的网络请求和资源加载,对页面加载性能有一定影响。 - 兼容性: 旧版本的浏览器可能对 postMessage 支持不完整,需要做兼容性处理。
Nginx
nginx反向代理 配置
这个配置允许任何域通过GET、POST和OPTIONS方法访问资源,并且允许一些常见的头信息字段。Access-Control-Max-Age
指令用于指定预检请求的结果能被缓存多久。
确保在实际部署时,根据安全和需求情况将Access-Control-Allow-Origin
设置为特定域,而不是*
(表示允许所有域),以减少跨站脚本攻击(XSS)的风险。
server {listen 80;server_name example.com;location / {# 设置允许跨域的域,* 表示允许任何域,也可以设置特定的域add_header 'Access-Control-Allow-Origin' '*';# 允许的方法add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';# 允许的头信息字段add_header 'Access-Control-Allow-Headers' 'User-Agent,Keep-Alive,Content-Type';# 缓存时间add_header 'Access-Control-Max-Age' 1728000;# 其他配置...}# 其他 server 配置...
}
.NetCore
在.NET Core中配置跨域非常简单。你可以在Startup.cs文件中的ConfigureServices方法添加跨域服务,并在Configure方法中配置跨域。
public class Startup
{// ...// 在ConfigureServices方法中添加跨域服务public void ConfigureServices(IServiceCollection services){// ...services.AddCors(options =>{options.AddPolicy("CorsPolicy",builder => builder.AllowAnyOrigin().AllowAnyMethod().AllowAnyHeader());});}// 在Configure方法中配置跨域public void Configure(IApplicationBuilder app, IWebHostEnvironment env){// ...// 使用跨域策略app.UseCors("CorsPolicy");// ...}
}
相关文章:
[ 跨域问题 ] 前后端以及服务端 解决跨域的各种方法
这篇文章主要介绍了跨域问题,包括其定义、产生原因及各种解决方法。原因是浏览器安全策略限制,方法有 JSONP、CORS、Domain、 postMessage、Nginx配置、.NetCore配置。 前言 什么是跨域问题? 在Web应用中,当一个网页的脚本试图去请求另一个域…...
网络安全之信息收集-实战-2
请注意,本文仅供合法和授权的渗透测试使用,任何未经授权的活动都是违法的。 目录 7、网络空间引擎搜索 8、github源码泄露 9、端口信息 10、框架指纹识别 11、WAF识别 12、后台查找 7、网络空间引擎搜索 FOFA:https://fofa.info/ 360 …...
利用飞书多维表格自动发布版本
文章目录 背景尝试1,轮询尝试2,长连接 背景 博主所在的部门比较奇特,每个车型每周都需要发版,所以实际上一周会发布好几个版本。经过之前使用流水线自动发版改造之后,发版的成本已经大大降低了,具体参考&a…...
深入内核讲明白Android Binder【一】
深入内核讲明白Android Binder【一】 前言一、Android Binder应用编写概述二、基于C语言编写Android Binder跨进程通信Demo0. Demo简介1. 服务的管理者server_manager.c2. Binder服务端代码实现 test_service.c2.1 实现思路2.2 完整实现代码 3. Binder客户端代码实现 test_clie…...
Photoshop(PS)——人像磨皮
1.新建一个文件,背景为白色,将图片素材放入文件中 2.利用CtrlJ 复制两个图层出来,选择第一个拷贝图层,选择滤镜---杂色---蒙尘与划痕 3.调整一下数值,大概能够模糊痘印痘坑,点击确定。 4.然后选择拷贝2图层…...
如何用Excel批量提取文件夹内所有文件名?两种简单方法推荐
在日常办公中,我们有时需要将文件夹中的所有文件名整理在Excel表格中,方便管理和查阅。手动复制文件名既费时又易出错,因此本文将介绍两种利用Excel自动提取文件夹中所有文件名的方法,帮助你快速整理文件信息。 方法一࿱…...
YOLOv8改进,YOLOv8通过RFAConv卷积创新空间注意力和标准卷积,包括RFCAConv, RFCBAMConv,二次创新C2f结构,助力涨点
摘要 空间注意力已广泛应用于提升卷积神经网络(CNN)的性能,但它存在一定的局限性。作者提出了一个新的视角,认为空间注意力机制本质上解决了卷积核参数共享的问题。然而,空间注意力生成的注意力图信息对于大尺寸卷积核来说是不足够的。因此,提出了一种新型的注意力机制—…...
【实验11】卷积神经网络(2)-基于LeNet实现手写体数字识别
👉🏼目录👈🏼 🍒1. 数据 1.1 准备数据 1.2 数据预处理 🍒2. 模型构建 2.1 模型测试 2.2 测试网络运算速度 2.3 输出模型参数量 2.4 输出模型计算量 🍒3. 模型训练 🍒4.模…...
chatgpt训练需要什么样的gpu硬件
训练像ChatGPT这样的大型语言模型对GPU硬件提出了极高的要求,因为这类模型的训练过程涉及大量的计算和数据处理。以下是训练ChatGPT所需的GPU硬件的关键要素: ### 1. **高性能计算能力** - **Tensor Cores**: 现代深度学习训练依赖于Tensor Cores&#…...
Kubernetes常用命令
Kubernetes常用命令 一、集群管理 kubectl cluster-info:显示集群信息,包括控制平面地址和服务的 URL。 kubectl get nodes:查看集群中的节点列表,包括节点状态、IP 地址等信息。 kubectl describe node <node-name>&…...
Flutter:key的作用原理(LocalKey ,GlobalKey)
第一段代码实现的内容:创建了3个块,随机3个颜色,每次点击按钮时,把第一个块删除 import dart:math; import package:flutter/material.dart; import package:flutter_one/demo.dart;void main() {runApp(const App()); }class App…...
R语言基础入门详解
文章目录 R语言基础入门详解一、引言二、R语言环境搭建1、安装R和RStudio1.1、步骤1.2、获取工作目录 三、R语言基础2、语法基础2.1、赋值操作2.2、注释 3、数据类型与结构3.1、向量3.2、矩阵 4、基本操作4.1、数据读取4.2、数据可视化 四、R语言使用示例4.1、统计分析示例4.2、…...
django启动项目报错解决办法
在启动此项目报错: 类似于: django.core.exceptions.ImproperlyConfigured: Requested setting EMOJI_IMG_TAG, but settings are not c启动方式选择django方式启动,以普通python方式启动会报错 2. 这句话提供了对遇到的错误的一个重要线索…...
详细描述一下Elasticsearch搜索的过程?
大家好,我是锋哥。今天分享关于【详细描述一下Elasticsearch搜索的过程?】面试题。希望对大家有帮助; 详细描述一下Elasticsearch搜索的过程? Elasticsearch 的搜索过程是其核心功能之一,允许用户对存储在 Elasticsea…...
Spring、SpringMVC、SpringBoot、Mybatis小结
Spring Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器(框架) Spring框架的核心特性包括依赖注入(Dependency Injection ,DI)、面向切面编程(Aspe…...
.NET 9 运行时中的新增功能
本文介绍了适用于 .NET 9 的 .NET 运行时中的新功能和性能改进。 文章目录 一、支持修剪的功能开关的属性模型二、UnsafeAccessorAttribute 支持泛型参数三、垃圾回收四、控制流实施技术.NET 安装搜索行为性能改进循环优化感应变量加宽Arm64 上的索引后寻址强度降低循环计数器可…...
Linux下安装mysql8.0版本
先确定我的下载安装的目录,安装文件是下载在 /opt/install 目录下面 (安装地址不同的话注意修改地址) 1.在线下载 wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz2.解压 tar -xvf mysql-8.0.20-linux-glibc2.12-x86_64.t…...
kvm-dmesg:从宿主机窥探虚拟机内核dmesg日志
在虚拟化环境中,实时获取虚拟机内核日志对于系统管理员和开发者来说至关重要。传统的 dmesg 工具可以方便地查看本地系统的内核日志,但在KVM(基于内核的虚拟机)环境下,获取虚拟机内部的内核日志则复杂得多。为了简化这…...
植物明星大乱斗15
能帮到你的话,就给个赞吧 😘 文章目录 player.hplayer.cppparticle.hparticle.cpp player.h #pragma once #include <graphics.h> #include "vector2.h" #include "animation.h" #include "playerID.h" #include &…...
go-zero(三) 数据库操作
go-zero 数据库操作 在本篇文章中,我们将实现一个用户注册和登录的服务。我们将为此构建一个简单而高效的 API,包括请求参数和响应参数的定义。 一、Mysql连接 1. 创建数据库和表 在 MySQL 中创建名为 test_zero的数据库,并创建user 表 …...
SQL面试题——间隔连续问题
间隔连续问题 某游戏公司记录的用户每日登录数据如下 +----+----------+ | id| date| +----+----------+ |1001|2021-12-12| |1001|2021-12-13| |1001|2021-12-14| |1001|2021-12-16| |1001|2021-12-19| |1001|2021-12-20| |1002|2021-12-12| |1002|2021-12-16| |1002|…...
vim配置 --> 在创建的普通用户下
在目录/etc/ 下面,有个名为vimrc 的文件,这是系统中公共的vim配置文件对所有用户都有效 我们现在创建一个普通用户 dm 创建好以后,我们退出重新链接 再切换到普通用户下 再输入密码(是不显示的,输入完后,…...
(计算机毕设)基于SpringBoot+Vue的房屋租赁系统的设计与实现
博主可接毕设设计!!! 各种毕业设计源码只要是你有的题目我这里都有源码 摘 要 社会的发展和科学技术的进步,互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大人民群众的喜爱,也逐渐进入了每个用户的使用。互…...
【含开题报告+文档+PPT+源码】基于SpringBoot的医院药房管理系统
开题报告 在科技迅速发展的今天,各行各业都在积极寻求与现代技术的融合,以提升自身的运营效率和竞争力。医疗行业作为关乎国计民生的关键领域,其信息化建设的步伐尤为迅速。医院药房作为医疗体系中的核心环节,其管理效率和服务质…...
基于SpringBoot的“数码论坛系统设计与实现”的设计与实现(源码+数据库+文档+PPT)
基于SpringBoot的“数码论坛系统设计与实现”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SpringBoot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统总体结构图 系统首页界面图 数码板…...
Linux-第2集-打包压缩 zip、tar WindowsLinux互传
欢迎来到Linux第2集,这一集我会非常详细的说明如何在Linux上进行打包压缩操作,以及解压解包 还有最最重要的压缩包的网络传输 毕竟打包压缩不是目的,把文件最终传到指定位置才是目的 由于打包压缩分开讲没有意义,并且它们俩本来…...
项目进度计划表:详细的甘特图的制作步骤
甘特图(Gantt chart),又称为横道图、条状图(Bar chart),是一种用于管理时间和任务活动的工具。 甘特图由亨利劳伦斯甘特(Henry Laurence Gantt)发明,是一种通过条状图来…...
Cargo Rust 的包管理器
Cargo->Rust 的包管理器 Cargi简介Cargo 的主要功能1. 创建项目2. 管理依赖3. 构建项目4. 运行项目5. 测试代码6. 检查代码7. 生成文档8. 发布和分享包 Cargo 的核心文件1. Cargo.toml2. Cargo.lock **Cargo 的生态系统** 常用命令总结Hello, Cargo! 示例 Cargi简介 Cargo …...
【Rust 编程语言工具】rustup-init.exe 安装与使用指南
rustup-init.exe 是用于安装和管理 Rust 编程语言工具链的 Windows 可执行文件。Rust 是一种系统级编程语言,旨在提供安全、并发和高性能的功能。rustup-init.exe 是官方提供的安装器,用于将 Rust 安装到 Windows 操作系统中,并配置相关环境。…...
集群聊天服务器(12)nginx负载均衡器
目录 负载均衡器nginx负载均衡器优势 如何解决集群聊天服务器跨服务器通信问题?nginx的TCP负载均衡配置nginx配置 负载均衡器 目前最多只能支持2w台客户机进行同时聊天 所以要引入集群,多服务器。 但是客户连哪一台服务器呢?客户并不知道哪一…...
上传文章网站/百度网页收录
什么是事务? 在数据库中,所谓事务是指一组逻辑操作单元即一组sql语句。当这个单元中的一部分操作失败,整个事务回滚,只有全部正确才完成提交。判断事务是否配置成功的关键点在于出现异常时事务是否会回滚 事务四大特性 1、原子性(Atomicit…...
vs2017网站开发组件/安徽seo
1. 问题描述: 让我们一起来玩扫雷游戏! 给定一个代表游戏板的二维字符矩阵。 M 代表一个未挖出的地雷,E 代表一个未挖出的空方块,B 代表没有相邻(上,下,左,右,和所有4个…...
做外贸出口的网站/网站策划是干什么的
%86时出现报错 Error in invoking target agent nmhs of makefile 解决方案在makefile中添加链接libnnz11库的参数修改$ORACLE_HOME/sysman/lib/ins_emagent.mk,将$(MK_EMAGENT_NMECTL)修改为:$(MK_EMAGENT_NMECTL) -lnnz11建议修改前备份原始文件[ora…...
做外贸都做哪些网站好免费下载/磁力搜索
CSRF(Cross Site Request Forgeries)跨网站请求伪造,也叫XSRF,通过伪装来自受信任用户的请求来攻击利用受信任网站。 与对比 xss:本网站运行了来自其它网站的脚本csrf:其它网站对本网站产生了影响一、攻击 利用用户登录态伪造http…...
wordpress用户筛选/佛山网站seo
眨眼间已经到了12月9号啦,昨天教资笔试出成绩,过啦嘿嘿,不过很快就要面试了,现在还是毫无准备 的状态,但我觉得应该开始准备起来了。 还是先学习前端的东西叭。 原来路由的权限设置跟工厂模式有关呢。 链接ÿ…...
做58类网站需要多少钱/品牌整合营销传播
每日一言:九十九次的理论不如一次的行动来的实际。 欢迎一起讨论和学习,QQ:732258496 QQ群:478720016 Android热更新Tinker 多渠道打包 加固的流程详解 热更新注意(经测试总结出) 1.protectedApp tr…...