HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(二)

上一篇只讲到前台操作,这篇专门涉及到Java后台处理,前台通过Ajax提交将Base64编码过的图片数据信息传到Java后台,然后Java这边进行接收处理,通过对图片数据信息进行Base64解码,之后使用流将图片数据信息上传至服务器进行保存,并且将图片的路径地址存进数据库。ok,废话不多说了,直接贴代码吧。

1、前台js代码:

$.ajax({
				async:false,//是否异步
				cache:false,//是否使用缓存
				type: "POST",
				data:{fileData:fileData,licenceName:licenceName,cust_tax_code:cust_tax_code,phoneNum:phoneNum,state_id:state_id},
				dataType: "json",
				timeout: 1000,
				contentType : 'application/x-www-form-urlencoded; charset=utf-8',
				url: $('#ctx').val()+"CustomerCheckServlet?action=uploadLicence",
				success: function(result){
					console.log(result);
					if(result == true){
						alert('Success Upload~~~');
					}else if(result == false){
						alert('Error Upload~~~');
					}
				},
				error: function(){
					alert("Error Linking~");
				}
			});

2、后台Java代码

/**
	 * 证件上传
	 * @param request
	 * @param response
	 * @throws IOException
	 */
	public void uploadLicence(HttpServletRequest request,HttpServletResponse response) throws IOException{
		log.info("=====================uploadLicence");
		df = new SimpleDateFormat("yyyy-MM-dd");

		String cust_tax_code = request.getParameter("cust_tax_code");
		String phoneNum = request.getParameter("phoneNum");
		String licenceName = request.getParameter("licenceName");

		String fileData = request.getParameter("fileData");//Base64编码过的图片数据信息,对字节数组字符串进行Base64解码
		String imgPath = uploadFile(fileData,liceneName);//进行文件上传操作,上传到服务器中存放(这里是上传到服务器项目文件夹中存到)

		boolean result = false;//最终上传成功与否的标志

		custCheckInfo = new CustomerCheckInfo();
		custCheckInfo.setCust_tax_code(cust_tax_code);
		custCheckInfo.setPhonenum(phoneNum);
		custCheckInfo.setUpdate_time(df.format(new Date()));

		boolean save_flag = customerService.saveRegistCertInfo(custCheckInfo);//保存路径

		//判断数据库中的路径是否存在,并且文件夹中的文件是否存在(判断是否上传成功的标志)
		boolean is_success = isSuccessUpload(licenceName, cust_tax_code, phoneNum);
		if(save_flag && is_success){
			result = true;
		}

		//如果证件上传成功,则记录到记录表中
		if(result){
			StateRecordInfo record = new StateRecordInfo();
			record.setCust_tax_code(cust_tax_code);
			record.setPhonenum(phoneNum);
			record.setState_id(state_id);

			saveStateRecord(record);//执行状态保存操作
		}

		System.out.println("===result:"+result);
		PrintWriter pw = response.getWriter();
		pw.print(result);
		pw.close();
	}
/**
	 * 文件上传
	 * @param fileData
	 * @param fileName
	 * @return
	 */
	public String uploadFile(String fileData,String fileName){
		//在自己的项目中构造出一个用于存放用户照片的文件夹
		String imgPath = this.getServletContext().getRealPath("/uploads/");
		//如果此文件夹不存在则创建一个
		File f = new File(imgPath);
		if(!f.exists()){
			f.mkdir();
		}
		//拼接文件名称,不存在就创建
		imgPath = imgPath + "/" + fileName + ".jpg";
		f = new File(imgPath);
		if(!f.exists()){
			f.mkdir();
		}

		log.info("====文件保存的位置:"+imgPath);

		//使用BASE64对图片文件数据进行解码操作
		BASE64Decoder decoder = new BASE64Decoder();
		try {
			//通过Base64解密,将图片数据解密成字节数组
			byte[] bytes = decoder.decodeBuffer(fileData);
			//构造字节数组输入流
			ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
			//读取输入流的数据
			BufferedImage bi = ImageIO.read(bais);
			//将数据信息写进图片文件中
			ImageIO.write(bi, "jpg", f);// 不管输出什么格式图片,此处不需改动
			bais.close();
		} catch (IOException e) {
			log.error("e:{}",e);
		}
		return imgPath;
	}

/**
	 * 判断是否成功上传
	 * @return
	 */
	public boolean isSuccessUpload(String licenceName,String cust_tax_code,String phonenum){
		boolean flag = false;
		String licencePath = "";//证件图片上传成功之后保存的路径

		custCheckInfo = customerService.getCustomerCheckInfo(cust_tax_code, phonenum);
		licencePath = custCheckInfo.getTax_regist_cert();

		//判断证件路径不为空并且在上传存放的文件夹中存在,就表明以上传成功
		File f = new File(licencePath);
		if(licencePath.length() >0 && f.exists()){
			flag = true;
		}
		return flag;
	}

好了,到这里就全部结束了,这就是HTML5+jQuery+Canvas调用手机拍照功能实现图片上传的全部实现过程,总感觉自己的思路有些混乱,嗯,慢慢进步吧!

时间: 2024-12-09 20:35:58

HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(二)的相关文章

H5拍照、选择图片上传组件核心

背景 前段时间项目重构,改成SSR的项目,但之前用的图片选择上传组件不支持SSR(server-side-render).遂进行了调研,发现很多的工具.但有的太大,有的使用麻烦,有的不满足使用需求.决定自己写一个h5移动端图片上传组件.图片上传是一个比较普遍的需求,PC端还好,移动端就不是特别好做了.下面将过程中一些重点的问题进行简单的记录. 重点 1.关于input 选择功能使用<input>标签实现.属性accept='image/*',:capture表示,可以捕获到系统默认的设备,比如

kindeditor扩展粘贴图片功能&amp;修改图片上传路径并通过webapi上传图片到图片服务器

前言 kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了. 而kindeditor却对图片的处理不够理想. 本篇博文需要解决的问题有两个: kindeditor扩展粘贴图片功能 kindeditor修改图片上传路径并通过webapi上传图片到图片服务器(支持分布式图片) 结果演示 1.扩展粘贴图片功能演示 2.修改图片上传路径演示: 我们的网站演示地址是:http://localhost:9393/ 我们的图片服务器地址是:http://localhost:9394/

monotouch拍照、选择图片上传实现

不多说,上码: 选择图片上传========> using System; using System.Drawing; using MonoTouch.AssetsLibrary; using MonoTouch.UIKit; using MonoTouch.Foundation; namespace world { public class ImageViewController : UIViewController { UIImagePickerController imagePicker;

Java带图片预览功能的图片上传兼容火狐ie

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Typ

MVC4中基于bootstrap和HTML5的图片上传Jquery自定义控件

场景:mvc4中上传图片,批量上传,上传前浏览,操作.图片进度条. 解决:自定义jquery控件 没有解决:非图片上传时,会有浏览样式的问题; 解决方案; 1.样式 – bootstrap 的css和图标与metro-ui-css的部分css 2.js 自定义控件 3.后台 mvc4 ------------------------------------------------- 1. [class*=border-color] { border: 2px solid; } .border-c

vue 移动端拍照压缩base64格式上传

啰嗦两句,因最近有个小项目要做一个拍照上传头像的功能,做的过程中出现了一些问题,针对这些问题做一下总结分享 问题: 1.图片转base64 2.手机拍照在ios和小米等手机下会旋转 3.图片的压缩 4.手机像素太大,进行一个等比缩放上传 啰嗦完了,上代码 <template> <div id="face"> <div class="faceBox"> <img src="" alt=""

Android使得手机拍照功能的发展(源共享)

Android系统调用手机拍照功能有两种方法来直接调用手机自带摄像头还有一个就是要当心自己的节拍. 例Camera360 强大的一个在每个操作系统都有一个手机摄影软件:您可以捕捉不同风格,不同特效的照片,同一时候具有云服务和互联网分享功能,全球用户已经超过2.5亿.如今专门的开发一款手机摄影软件肯定没多大意义,已经比只是这些前辈了.我们仅仅需学会怎样调用手机自带的摄像机完毕拍照并把照片获取过来,为用户提供上传头像,发表图文微博,传送图片的功能就可以. 完毕上述的功能十分的简单,甚至不须要在清单文

Android开发之手机拍照功能的实现(源代码分享)

Android系统里调用手机拍照的功能有两种方法一种直接调用手机自带的相机另一种就是使用自己做的拍照应用.比如Camera360 一款于各操作系统都有的的功能强大的手机摄影软件:能拍摄出不同风格,不同特效的照片,同时具有云服务和互联网分享功能,全球用户已经超过2.5亿.现在专门的开发一款手机摄影软件肯定没多大意义,已经比不过这些前辈了,我们只需学会如何调用手机自带的摄像机完成拍照并把照片获取过来,为用户提供上传头像,发表图文微博,传送图片的功能即可.完成上述的功能十分的简单,甚至不需要在清单文件

HTML5 Canvas简简单单实现手机九宫格手势密码解锁

原文:HTML5 Canvas简简单单实现手机九宫格手势密码解锁 早上花了一个半小时写了一个基于HTML Canvas的手势解锁,主要是为了好玩,可能以后会用到. 思路:根据配置计算出九个点的位置,存入一个数组,当然存入数组的顺序的索引是: 第一行:0   1  2   第二行:3  4  5 第三行:6  7  8 然后就根据这个坐标数组去绘制九个点 再则我们需要一个保存选中点的数组,每当touchmove事件就判断当前触摸点和那个点的距离小于圆的半径  如果为真的话 那么就添加进入选中点的数