通过JSP怎样上传图片到服务器

通过JSP怎样上传图片到服务器,第1张

1.限制文件上传类型只能是图片

function checkFileType(name,file){

var extArray = new Array(".doc",".docx")

var allowSubmit = false

if (!file){

return

}

while (file.indexOf("\\") != -1){

file = file.slice(file.indexOf("\\") + 1)

}

var ext = file.slice(file.indexOf(".")).toLowerCase()

for (var i = 0i <extArray.lengthi++) {

if (extArray[i] == ext){

allowSubmit = true

break

}

}

if(!allowSubmit){

alert("只能上传以下格式的文件:"+ (extArray.join("")) + "\n请重新选择再上传.")

document.getElementById(name).value = ""

}

}

其中:extArray是要求文件类型。可自行定义。

2.引入jQuery外部文件

jquery-2.1.4.min.js

3.编写js代码

$(function () {

$('#txtfilePath1').uploadReview({

width: 350,

height: 350,

target: '#uploadReview1_content'

})

})

其中:txtfilePath1是input:file。width,height是预览图片的宽度和高度。target是显示预览图片的位置。

4.编写jsp页面代码

<body>

<input type="text" class="yourClassName" name="filePath1" id="filePath1"/>

<input type="file" id="txtfilePath1" name="txtfilePath1" style="display:none">

<input type="button" onclick="txtfilePath1.click()" id="fileup1" name="fileup1" class="searchThing"value="上传">

</body>

注: 这个是很久以前在网上看到的,就整理了下来,但是这么久都没用过,所以也没调试过,你自己试一试研究研究, 再来网上很多博客里,他们写的很详细的,可以去看看

1、首先需要新建Dynamic web project项目,建好之后在WebContent里面的内容如图所示。

2、在body里在body里面设置背景图片,如图所示body部分内容。

3、在body里面代码操作好之后,运行效果如图所示。

4、也可以设置背景颜色,直接将url(images/backImage.jpg)替换成#f00000。

5、直接写页面代码操作好之后,运行效果如下。

6、也可以在head里面设操作代码,如图所示。

7、在head里面代码操作好之后,运行效果如下。

扩展资料:

JSP将Java代码和特定变动内容嵌入到静态的页面中,实现以静态页面为模板,动态生成其中的部分内容。JSP引入了被称为“JSP动作”的XML标签,用来调用内建功能。另外,可以创建JSP标签库,然后像使用标准HTML或XML标签一样使用它们。

标签库能增强功能和服务器性能,而且不受跨平台问题的限制。JSP文件在运行时会被其编译器转换成更原始的Servlet代码。JSP编译器可以把JSP文件编译成用Java代码写的Servlet,然后再由Java编译器来编译成能快速执行的二进制机器码,也可以直接编译成二进制码。

提交页面表单

<form action="up.jsp" enctype="multipart/form-data" method="post">

<input type="file" name="file">

<input type="submit" value="确定">

</form>

上传页面up.jsp

<%@page import="java.io.FileWriter"%>

<%@ page language="java" contentType="text/htmlcharset=UTF-8"

import="java.io.*"

pageEncoding="UTF-8"%>

<%

/**

协议头四行内容

45 -----------------------------7de231211204c4

80 Content-Disposition: form-dataname="file"filename="xx.txt"

26 Content-Type: text/plain

2

标记文件结尾

-----------------------------7de231211204c4--

**/

ServletInputStream sin = request.getInputStream()

byte[] buffer = new byte[1024 * 8]

int length = 0, row = 0

String mark = ""

String filename = ""

while ((length = sin.readLine(buffer, 0, buffer.length)) >0) {

out.println(length + "" + new String(buffer, 0, length, "UTF-8") + "<br>")

String s = new String(buffer, 0, length, "UTF-8")

if (row == 0)

mark = s.trim()

else if (s.indexOf("filename=") >0) {

int end = s.lastIndexOf("\"")

int start = s.substring(0, end).lastIndexOf("\"")

filename = s.substring(start + 1, end)

} else if ("".equals(s.trim()))

break

row ++

}

out.println("filename:" + filename + "<br>")

filename = request.getRealPath("/") + "../" + filename

FileOutputStream fout = new FileOutputStream(filename)

while ((length = sin.readLine(buffer, 0, buffer.length)) >0) {

String s = new String(buffer, 0, length)

if (s.startsWith(mark))

break

fout.write(buffer, 0, length)

}

fout.flush()

fout.close()

File f = new File(filename)

out.println(f.exists())

out.println(f.getAbsolutePath())

%>


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/260001.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-16
下一篇2023-04-16

发表评论

登录后才能评论

评论列表(0条)

    保存