图片上传回显,并以clob数据类型存入数据库

照片本地上传回显以及Oracle数据库保存:
1.jsp页面图片加载代码

<div>
	<img src="./images/none.jpg" height="140px" width="100%"
		id="tp1" readonly="readonly">
	<input id="upload" name="file"
		style="width: 100px; display: none;" class="form-control"
		accept="image/*" type="file" />
	<input type="hidden" name="VGrtp" id="VGrtp"
		class="form-control" />
</div>

2.回显js代码:
(1.)全局变量定义

var url1=window.URL;
var tpxx1;

(2.)初始加载方法

//图片显示事件
	jQuery('#tp1').click(function () { 
		jQuery("#upload").click(); //隐藏了input:file样式后,点击头像就可以本地上传 
		jQuery("#upload").bind("change",function(){ 
			var objUrl = getObjectURL(this.files[0]) ; //获取图片的路径,该路径不是图片在本地的路径 
			if (objUrl) {jQuery("#tp1").attr("src", objUrl) ; //将图片路径存入src中,显示出图片 
			} 
		});
		var input = document.getElementById("upload");
		readimg1(input,tpxx1);
	}); 

(3.)图片处理方法


// 图片处理方法
function getObjectURL(file) { 
	if (window.createObjectURL!=undefined) { // basic 
		url = window.createObjectURL(file) ; 
	} else if (window.URL!=undefined) { // mozilla(firefox) 
		url = url1.createObjectURL(file) ; 
	} else if (window.webkitURL!=undefined) { // webkit or chrome 
		url = window.webkitURL.createObjectURL(file) ; 
	} 
	return url ; 
}
function readimg1(input,tpxx){
	if(typeof FileReader==='undefined'){
		alert("抱歉,你的浏览器不支持 FileReader");
		input.setAttribute('disabled','disabled');
	}else{
		input.addEventListener('change',readFile1,false);
	}
	function readFile1(){
		var file = this.files[0];
		if(!/image\/\w+/.test(file.type)){
			alert("文件必须为图片!");
			return false;
		}
		var reader = new FileReader();
		reader.readAsDataURL(file);
		reader.onload = function(e){
			dealImage(this.result,{width:148},function(base){//执行压缩方法
				document.getElementById('tp1').setAttribute('src',base);//将压缩之后的数据添加给pic2
				tpxx1=base;
				console.log(tpxx1);
			});
		} 
	}
}
/**
 * 图片压缩,默认同比例压缩
 * @param {Object} path
 * pc端传入的路径可以为相对路径,但是在移动端上必须传入的路径是照相图片储存的绝对路径
 * @param {Object} obj
 * obj 对象 有 width, height, quality(0-1)
 * @param {Object} callback
 * 回调函数有一个参数,base64的字符串数据
 */
function dealImage(path, obj, callback){
	var img = new Image();
	img.src = path;
	img.onload = function(){
		var that = this;
		// 默认按比例压缩
		var w = that.width,
		h = that.height,
		scale = w / h;
		w = obj.width || w;
		h = obj.height|| (w / scale);
		var quality = 0.7; // 默认图片质量为0.7
		//生成canvas
		var canvas = document.createElement('canvas');
		var ctx = canvas.getContext('2d');
		// 创建属性节点
		var anw = document.createAttribute("width");
		anw.nodeValue = w;
		var anh = document.createAttribute("height");
		anh.nodeValue = h;
		canvas.setAttributeNode(anw);
		canvas.setAttributeNode(anh);
		ctx.drawImage(that, 0, 0, w, h);
		// 图像质量
		if(obj.quality && obj.quality <= 1 && obj.quality > 0){
			quality = obj.quality;
		}
		// quality值越小,所绘制出的图像越模糊
		var base64 = canvas.toDataURL('image/jpeg', quality );
		// 回调函数返回base64的值
		callback(base64);
	}
}

上面的tpxx1是经过解析后的图片信息,例子:() 可以直接以clob的数据类型在数据库中存储.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值