- 后端传入文件流,前台pdf展示(pc端和手机端)
w001yy
前端javascript
近日项目用到的用文件流传递pdf文件的情况,后端将数据流传到前端,需要前端进行处理然后再预览下载,总结了一下几点方法,1.PC端一开始想引用pdf.js插件进行实现,但是总是白屏,借鉴的文章是https://www.jianshu.com/p/242525315bf6,用了里面的方法测试了,但是一直是白屏,展示不出pdf,也没有看到错误提示,最后直接用window.open(url),其中url表
- vue使用window.open()跳转页面
scorpion_V
vueJavaScript前端javascriptvue.js
项目场景:提示:项目需要vue带参数跳转打开新页面、新窗口:例如:点击机巢监控按钮,在当前页面重新打开一个窗口到另一个页面(同时把参数全部带过去)window.open()的用法open()方法用于打开一个新的浏览器窗口或查找一个已命名的窗口。window.open(URL,name,specs,replace)specs可选。一个逗号分隔的项目列表。支持以下值:channelmode=yes|n
- VUE在线预览word、pdf、excel等文档
菜鸟程序猿、
vue.jspdf前端
http://www.pfile.com.cn/api/profile/onlinePreview?url=(需要在线查看的文档地址)vue代码window.open('http://www.pfile.com.cn/api/profile/onlinePreview?url='+encodeURIComponent(“需要在线查看的文档地址”));文档参考:http://www.pfile.co
- window.open被拦截解决
SmailEvery
项目开发中遇到window.open写在回调里被浏览器拦截.解决办法是在请求时新开一个tab页,然后再请求的回调里修改这个tab页的地址.letnewWindow=window.open('about:blank');//新开一个tab页返回一个window对象axios.post(url}).then(response=>{if(response.data.status.code===1){ne
- 关于前端实现文件下载功能
大鱼前端
前端
在Web开发中,前端下载文件是一个常见的需求。根据文件来源和下载方式的不同,前端下载文件可以采用多种方案。下面将介绍几种常见的前端下载文件方案。1、通过window.open()打开新页面下载文件window.open(`url`, "_self");使用场景:下载excel文件,后端提供接口,接口返回的是文件流,可以直接使用window.open(),最简单的方式。优点:最简洁;弊端:当参数错误
- window.open漏洞揭秘:你了解多少?
安全
window.open是javascript中的一个方法,用于在新的浏览器窗口或标签页中打开指定的URL。然而,如果不正确地使用,它可能会引入安全漏洞。一、window.open漏洞DemoDemo是一个简单的html,点击button,然后通过window.open打开另一个地址,比如百度首页。如下截图所示:点击button后,会新开标签页,打开百度的页面。如下截图所示:详情请查看:window
- HTML页面跳转及参数传递
王国的荣耀
HTML页面跳转window.open(url,"","width=600,height=400");第二个参数:_self,在当前窗口打开窗口;_blank(默认值),在另外的新建窗口打开新窗口;window.location.href="https://www.yinxi.net";//在同当前窗口中打开窗口window.history.back(-1);//返回上一页面HTML参数传递:ur
- window.open(url)新窗口打开链接被浏览器拦截解决方案
Greens_dbd2
在浏览器的安全机制里,非用户触发的window.open(url)来打开新的链接方法是会被拦截的。(window.open(url,”_self”)改变当前的窗口是可以生效的)。只有直接使用js调用window.open(url);尤其是ajax请求回调或异步回调之后调用,打开新窗口时是会被拦截。常见解决方法:1.在超链接里加入onclick事件2.延迟打开setTimeout('window.o
- window.open 防止浏览器拦截
天渺工作室
https://blog.csdn.net/sinat_37255207/article/details/89374416网上试了很多方法最终只有一种可以```varnewWin=window.open('https://www.baidu.com/');wxPublic().then(res=>{//重定向到目标页面if(res.data.statusCode!='200'){newWin.lo
- 前端下载文件有哪些方式
西京刀客
前端js
前端下载文件有哪些方式在前端,最常见和最常用的文件下载方式是:使用标签的download属性:创建一个标签,并设置其href属性为文件的URL,然后使用download属性指定下载的文件名。这种方式简单直接,适用于下载单个文件,例如图片、文档、音频或视频等。window.open(imageUrl,‘_blank’)window.open方法可以在新的浏览器窗口或标签页中打开指定的URL。通过将文
- vue 下载二进制流文件
卿卿qing
Vue前端JaveScript
平时在前端下载文件有两种方式,一种是后台提供一个URL,然后用window.open(URL)下载;另一种是后台直接返回文件的二进制内容,然后前端转化再下载,下面主要说的是第二种实现方式Blob、ajax(axios)mdn上是这样介绍Blob的:Blob对象表示一个不可变、原始数据的类文件对象。Blob表示的不一定是JavaScript原生格式的数据具体使用axios({method:'post
- window.open 跳转http自动重定向https问题
he_wen_jian
http网络协议网络
我们正常跳转一个新页面打开链接方法是:window.open("http://baidu.com","_blank")这时候有些网站会自动重定向https,事实上我们有时候需要跳转http,以下是解决方案window.open("http://baidu.com","theFrame")
- 前端解决浏览器直接打开图片URL,下载问题
xiaoming_w
node前端js下载图片前端
本周做的项目中有一个下载图片的功能,拿到后台返回的url,像文件一样,直接window.open,发现图片没有像文件一样被下载,而是重新打开了一个页面展示图片。然后我尝试了转成base64等方法也还是有跨域的问题。后来就想着自己把这个url,发送给Node,node转成数据流返回给我,我再下载。话不多说,上代码:vue前端代码:downZip(urls){//urls为图片地址if(!urls){
- JS实现页面跳转的几种方法
TTong___
js前端javascriptvue.js
JS实现页面跳转链接的几种方法1.在当前窗口打开一个新的页面window.location.href=url2.新开窗口打开一个新的页面window.open(url)3.当前窗口的页面被替换为一个新的页面url,替换后不可以回退到上个页面location.replace(url)4.当前窗口的页面转为为一个新的页面URL,与方法3类似,但此方法可回退至上一页面localtion.assign(u
- html 关闭当前tab页面,js关闭浏览器的tab页(兼容)
Home Talk
html关闭当前tab页面
在console中弹出提示"Scriptsmaycloseonlythewindowsthatwereopenedbyit"(脚本只能关闭它所打开的窗口),[如下图所示],不明白是什么原因。经过一段时间的折腾。终于明白了问题所在。首先,什么是非弹出窗口呢?非弹出窗口,即是指(opener=null及非window.open()打开的窗口,比如URL直接输入的浏览器窗体,或由其它程序调用产生的浏览器
- js关闭浏览器的tab页
无心使然云中漫步
javascriptjavascript开发语言
1需求利用js关闭浏览器tab页2代码window.close()//如在iframe中,则需要window.top.close()3注意当前tab是非弹出窗口,无法关闭,控制台会有如下提示非弹出窗口,指opener=null以及非window.open()打开的窗口(比如URL直接输入的浏览器窗口,或由其它程序调用产生的浏览器窗口)
- JS中的全局对象、原型与原型链
Nelson_sylar
一、JS中全局对象与浏览器中的全局对象JS中默认全局对象是global,而在浏览器的全局对象是window,如window.alert('hi');window.open('http://baidu.com')当然也可省略window,写成alert('hi');open('http://baidu.com')window对象它的属性有两种:ECMAScript规定的:parseInt,parse
- window.open实现跳转网页
爱写代码的派大星
javascript
2024.1.18今天我学习了如何用js进行跳转网页,代码如下:window.open('http://'+xxxx,'_blank')//xxxx表示接口路径,如'192.168.x.xxx'
- 前端下载二进制流文件
会编程的林俊杰
前端html5htmljavascript
一、两种方式:1、后台提供一个URL,然后用window.open(URL)下载2、后台直接返回文件的二进制内容,然后前端转化一下再下载二、Blob对象:1、Blob,全称:BinaryLargeObject,表示不可变的类似文件对象的二进制数据。2、构造函数:Blob(blobParts[,options])参数说明:blobParts:数组类型,数组中的每一项连接起来构成Blob对象的数据,数
- JS下载图片和文件,防止浏览器直接打开
伴歌知行
1、可以直接通过访问文件的url进行下载download或者window.open(url,"_blank");2、对于图片、pdf、txt等浏览器支持直接打开预览的文件,则不会进行下载解决办法:模拟发送http请求,将文件链接转换成文件流,然后使用a标签download属性进行下载。点击下载functiondownload(){leturl='文件地址'letname='文件名称'//发送htt
- js直接下载附件和通过blob数据类型下载文件
shenzhipeng1023
js代代码库js附件下载js下载blobblob文件下载js文件下载文件下载
js下载文件方式有使用a标签的,也有直接用window.open的,还有用form表单的;这里采用的是a标签的下载方式,一种是url直接下载,另一种是文件的blob数据类型进行下载。文件blob数据类型的获取一般是后端返回文件的二进制流,前端通过请求工具获取为blob数据类型进行下载;也可以这直接通过ajax或fetch等将url转化为blob数据类型,一些特殊的附件直接通过url下载,浏览器可能
- 浏览器打开页面的几种方式
白小白灬
JavaScriptjavascript
window.open(Url,"_self","修改打开网页的大小");_blank:URL加载到一个新的窗口。这是默认,且可以设置窗口大小_parent:URL加载到父框架,没有时同_self_self:URL替换当前页面_top:URL替换任何可加载的框架集,没有时同_selfwindow.open('https://www.baidu.com','_blank','width=200,he
- vue项目获取浏览器地址栏参数方法 ?aaa=111&bbb=222(非路由传参)
一室易安
vue项目获取浏览器地址栏参数?aaa=111&bbb=222(非路由传参)项目中遇到一个需求,就是另一个管理系统带参直接单纯的跳转跳转到vuepc项目中的某个页面,后再初始化查询数据,参数以地址栏的形式传入管理系统:打开新地址地址(跳转新页面使用_blank)letobj={id:21,name:“测试传参”};window.open(“http://localhost:8080/loginM?
- iframe/window.open/a三种标签打开新页面或新窗口设置请求头;实现免密登录
别拿曾经看以后~
前端javascript前端javascript开发语言
前言:对于前端来说,一般在登录获取token之后会把token存入缓存以及放置在RequestHeaders请求头中,但是使用iframe/window.open/a这三种标签打开新页面或新窗口是没有办法把请求头带过去的,这个时候就需要自己设置请求头,有如下有两种办法:方法一(不推荐):第一种方法可以说是最不得已使用但是也能实现的方法,就是在跳转链接后面拼token,http://localhos
- Python—selenium实现以一个浏览器多个标签页打开多个网页
chaodaibing
seleniumseleniumweb
如何用selenium打开新的标签页?网上都说是实现输入Ctrl+t即可,但测试完全不可行。经过反复摸索,终于发现了打开新的标签页的可靠办法,由此实现以一个浏览器打开多个标签页,代码分享给大家。fromseleniumimportwebdriverjs="window.open('{}','_blank');"#第一个网站driver=webdriver.Chrome()driver.get('h
- js中window.open怎么修改新窗口名字
前端小臻
javascript开发语言ecmascript
在JavaScript中,window.open()方法用于打开新的浏览器窗口。然而,这个方法并不允许你直接修改新窗口的名字。新窗口的名称是浏览器定义的,通常与URL相关,并且不能通过JavaScript代码来修改。如果你想在用户打开新窗口时为其设置一个名字,你可能需要在打开新窗口之前先在服务器端或客户端存储这个信息。然后在新窗口加载的时候,可以通过JavaScript来读取这个信息并设置其名字。
- 前端pdf预览、pdfjs的使用
无知的小菜鸡
学习vue基础前端pdfjavascript
前言关于前端预览pdf,最简单的方式是使用window.open()直接在浏览器的新窗口打开就好,浏览器本身也是提供了非常多的功能但是因为客户的某些需求,不能使用浏览器自身的功能。后来又使用了https://github.com/gjTool/pdfh5,也挺好用的,操作比较简单。使用了一段时间吧,但是还是由于客户的某些需求,最终还是放弃了。百度查询了一下可以使用https://github.co
- selenium 新建、切换、关闭标签页(python)
嘿,不许笑
python爬虫selenium测试工具
注:python调用selenium版本4.1.0新建标签页js="window.open('http://www.baidu.com','_blank');"#打开新标签页self.driver.execute_script(js)切换标签页windows=drive.window_handles#获取所有句柄#windows是个列表,记录当前打开的所有标签页driver.switch_to.w
- vue2挂载全局方法/组件
禾苗种树
vuejavascript前端vue.js
Vue2挂载全局方法/组件思路全局类的功能一般都写在main.js页面;需求把自己写的方法挂载到全局,这样每个组件都能使用了,比如下载方法代码//common.js文件//通用下载方法exportfunctiondownload(url){window.open(baseURL+url)}//main.jsimport{download,}from"@/utils/common";//分页组件im
- Excel上传到服务器,并下载返回
迷路人~
工具-Ecxeljava开发语言
需求:将一个Excel用户名单从后台管理系统上传到后台,后台判断名单中的人是否已在数据库中,然后将已存在的人用excel形式返回给前端。问题:后台管理使用的是若依框架,接收不了从后台推流的Excel【也可能是我的方式错误】解决方案:无奈下只能先将要返给前端的已存在的用户名单上传到服务器,然后返回给前端一个存储地址,前端根据存储地址,使用window.open()从服务器上拉取Excel,然后推流给
- Nginx负载均衡
510888780
nginx应用服务器
Nginx负载均衡一些基础知识:
nginx 的 upstream目前支持 4 种方式的分配
1)、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2)、weight
指定轮询几率,weight和访问比率成正比
- RedHat 6.4 安装 rabbitmq
bylijinnan
erlangrabbitmqredhat
在 linux 下安装软件就是折腾,首先是测试机不能上外网要找运维开通,开通后发现测试机的 yum 不能使用于是又要配置 yum 源,最后安装 rabbitmq 时也尝试了两种方法最后才安装成功
机器版本:
[root@redhat1 rabbitmq]# lsb_release
LSB Version: :base-4.0-amd64:base-4.0-noarch:core
- FilenameUtils工具类
eksliang
FilenameUtilscommon-io
转载请出自出处:http://eksliang.iteye.com/blog/2217081 一、概述
这是一个Java操作文件的常用库,是Apache对java的IO包的封装,这里面有两个非常核心的类FilenameUtils跟FileUtils,其中FilenameUtils是对文件名操作的封装;FileUtils是文件封装,开发中对文件的操作,几乎都可以在这个框架里面找到。 非常的好用。
- xml文件解析SAX
不懂事的小屁孩
xml
xml文件解析:xml文件解析有四种方式,
1.DOM生成和解析XML文档(SAX是基于事件流的解析)
2.SAX生成和解析XML文档(基于XML文档树结构的解析)
3.DOM4J生成和解析XML文档
4.JDOM生成和解析XML
本文章用第一种方法进行解析,使用android常用的DefaultHandler
import org.xml.sax.Attributes;
- 通过定时任务执行mysql的定期删除和新建分区,此处是按日分区
酷的飞上天空
mysql
使用python脚本作为命令脚本,linux的定时任务来每天定时执行
#!/usr/bin/python
# -*- coding: utf8 -*-
import pymysql
import datetime
import calendar
#要分区的表
table_name = 'my_table'
#连接数据库的信息
host,user,passwd,db =
- 如何搭建数据湖架构?听听专家的意见
蓝儿唯美
架构
Edo Interactive在几年前遇到一个大问题:公司使用交易数据来帮助零售商和餐馆进行个性化促销,但其数据仓库没有足够时间去处理所有的信用卡和借记卡交易数据
“我们要花费27小时来处理每日的数据量,”Edo主管基础设施和信息系统的高级副总裁Tim Garnto说道:“所以在2013年,我们放弃了现有的基于PostgreSQL的关系型数据库系统,使用了Hadoop集群作为公司的数
- spring学习——控制反转与依赖注入
a-john
spring
控制反转(Inversion of Control,英文缩写为IoC)是一个重要的面向对象编程的法则来削减计算机程序的耦合问题,也是轻量级的Spring框架的核心。 控制反转一般分为两种类型,依赖注入(Dependency Injection,简称DI)和依赖查找(Dependency Lookup)。依赖注入应用比较广泛。
- 用spool+unixshell生成文本文件的方法
aijuans
xshell
例如我们把scott.dept表生成文本文件的语句写成dept.sql,内容如下:
set pages 50000;
set lines 200;
set trims on;
set heading off;
spool /oracle_backup/log/test/dept.lst;
select deptno||','||dname||','||loc
- 1、基础--名词解析(OOA/OOD/OOP)
asia007
学习基础知识
OOA:Object-Oriented Analysis(面向对象分析方法)
是在一个系统的开发过程中进行了系统业务调查以后,按照面向对象的思想来分析问题。OOA与结构化分析有较大的区别。OOA所强调的是在系统调查资料的基础上,针对OO方法所需要的素材进行的归类分析和整理,而不是对管理业务现状和方法的分析。
OOA(面向对象的分析)模型由5个层次(主题层、对象类层、结构层、属性层和服务层)
- 浅谈java转成json编码格式技术
百合不是茶
json编码java转成json编码
json编码;是一个轻量级的数据存储和传输的语言
在java中需要引入json相关的包,引包方式在工程的lib下就可以了
JSON与JAVA数据的转换(JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非
常适合于服务器与 JavaScript 之间的数据的交
- web.xml之Spring配置(基于Spring+Struts+Ibatis)
bijian1013
javaweb.xmlSSIspring配置
指定Spring配置文件位置
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/spring-dao-bean.xml,/WEB-INF/spring-resources.xml,
/WEB-INF/
- Installing SonarQube(Fail to download libraries from server)
sunjing
InstallSonar
1. Download and unzip the SonarQube distribution
2. Starting the Web Server
The default port is "9000" and the context path is "/". These values can be changed in &l
- 【MongoDB学习笔记十一】Mongo副本集基本的增删查
bit1129
mongodb
一、创建复本集
假设mongod,mongo已经配置在系统路径变量上,启动三个命令行窗口,分别执行如下命令:
mongod --port 27017 --dbpath data1 --replSet rs0
mongod --port 27018 --dbpath data2 --replSet rs0
mongod --port 27019 -
- Anychart图表系列二之执行Flash和HTML5渲染
白糖_
Flash
今天介绍Anychart的Flash和HTML5渲染功能
HTML5
Anychart从6.0第一个版本起,已经逐渐开始支持各种图的HTML5渲染效果了,也就是说即使你没有安装Flash插件,只要浏览器支持HTML5,也能看到Anychart的图形(不过这些是需要做一些配置的)。
这里要提醒下大家,Anychart6.0版本对HTML5的支持还不算很成熟,目前还处于
- Laravel版本更新异常4.2.8-> 4.2.9 Declaration of ... CompilerEngine ... should be compa
bozch
laravel
昨天在为了把laravel升级到最新的版本,突然之间就出现了如下错误:
ErrorException thrown with message "Declaration of Illuminate\View\Engines\CompilerEngine::handleViewException() should be compatible with Illuminate\View\Eng
- 编程之美-NIM游戏分析-石头总数为奇数时如何保证先动手者必胜
bylijinnan
编程之美
import java.util.Arrays;
import java.util.Random;
public class Nim {
/**编程之美 NIM游戏分析
问题:
有N块石头和两个玩家A和B,玩家A先将石头随机分成若干堆,然后按照BABA...的顺序不断轮流取石头,
能将剩下的石头一次取光的玩家获胜,每次取石头时,每个玩家只能从若干堆石头中任选一堆,
- lunce创建索引及简单查询
chengxuyuancsdn
查询创建索引lunce
import java.io.File;
import java.io.IOException;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Docume
- [IT与投资]坚持独立自主的研究核心技术
comsci
it
和别人合作开发某项产品....如果互相之间的技术水平不同,那么这种合作很难进行,一般都会成为强者控制弱者的方法和手段.....
所以弱者,在遇到技术难题的时候,最好不要一开始就去寻求强者的帮助,因为在我们这颗星球上,生物都有一种控制其
- flashback transaction闪回事务查询
daizj
oraclesql闪回事务
闪回事务查询有别于闪回查询的特点有以下3个:
(1)其正常工作不但需要利用撤销数据,还需要事先启用最小补充日志。
(2)返回的结果不是以前的“旧”数据,而是能够将当前数据修改为以前的样子的撤销SQL(Undo SQL)语句。
(3)集中地在名为flashback_transaction_query表上查询,而不是在各个表上通过“as of”或“vers
- Java I/O之FilenameFilter类列举出指定路径下某个扩展名的文件
游其是你
FilenameFilter
这是一个FilenameFilter类用法的例子,实现的列举出“c:\\folder“路径下所有以“.jpg”扩展名的文件。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
- C语言学习五函数,函数的前置声明以及如何在软件开发中合理的设计函数来解决实际问题
dcj3sjt126com
c
# include <stdio.h>
int f(void) //括号中的void表示该函数不能接受数据,int表示返回的类型为int类型
{
return 10; //向主调函数返回10
}
void g(void) //函数名前面的void表示该函数没有返回值
{
//return 10; //error 与第8行行首的void相矛盾
}
in
- 今天在测试环境使用yum安装,遇到一个问题: Error: Cannot retrieve metalink for repository: epel. Pl
dcj3sjt126com
centos
今天在测试环境使用yum安装,遇到一个问题:
Error: Cannot retrieve metalink for repository: epel. Please verify its path and try again
处理很简单,修改文件“/etc/yum.repos.d/epel.repo”, 将baseurl的注释取消, mirrorlist注释掉。即可。
&n
- 单例模式
shuizhaosi888
单例模式
单例模式 懒汉式
public class RunMain {
/**
* 私有构造
*/
private RunMain() {
}
/**
* 内部类,用于占位,只有
*/
private static class SingletonRunMain {
priv
- Spring Security(09)——Filter
234390216
Spring Security
Filter
目录
1.1 Filter顺序
1.2 添加Filter到FilterChain
1.3 DelegatingFilterProxy
1.4 FilterChainProxy
1.5
- 公司项目NODEJS实践0.1
逐行分析JS源代码
mongodbnginxubuntunodejs
一、前言
前端如何独立用nodeJs实现一个简单的注册、登录功能,是不是只用nodejs+sql就可以了?其实是可以实现,但离实际应用还有距离,那要怎么做才是实际可用的。
网上有很多nod
- java.lang.Math
liuhaibo_ljf
javaMathlang
System.out.println(Math.PI);
System.out.println(Math.abs(1.2));
System.out.println(Math.abs(1.2));
System.out.println(Math.abs(1));
System.out.println(Math.abs(111111111));
System.out.println(Mat
- linux下时间同步
nonobaba
ntp
今天在linux下做hbase集群的时候,发现hmaster启动成功了,但是用hbase命令进入shell的时候报了一个错误 PleaseHoldException: Master is initializing,查看了日志,大致意思是说master和slave时间不同步,没办法,只好找一种手动同步一下,后来发现一共部署了10来台机器,手动同步偏差又比较大,所以还是从网上找现成的解决方
- ZooKeeper3.4.6的集群部署
roadrunners
zookeeper集群部署
ZooKeeper是Apache的一个开源项目,在分布式服务中应用比较广泛。它主要用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务、状态同步、集群管理、配置文件管理、同步锁、队列等。这里主要讲集群中ZooKeeper的部署。
1、准备工作
我们准备3台机器做ZooKeeper集群,分别在3台机器上创建ZooKeeper需要的目录。
数据存储目录
- Java高效读取大文件
tomcat_oracle
java
读取文件行的标准方式是在内存中读取,Guava 和Apache Commons IO都提供了如下所示快速读取文件行的方法: Files.readLines(new File(path), Charsets.UTF_8); FileUtils.readLines(new File(path)); 这种方法带来的问题是文件的所有行都被存放在内存中,当文件足够大时很快就会导致
- 微信支付api返回的xml转换为Map的方法
xu3508620
xmlmap微信api
举例如下:
<xml>
<return_code><![CDATA[SUCCESS]]></return_code>
<return_msg><![CDATA[OK]]></return_msg>
<appid><