前台上传多张图片,保存在一个字段里前后端代码

本文介绍了一个前端上传多张图片并保存到同一字段的解决方案。内容包括上传成功后的字段处理,如判断已有值则使用管道符号连接新值,无值则直接赋值。同时提及了在后台展示时如何通过分割该字段来显示图片。
摘要由CSDN通过智能技术生成
<script type="text/javascript">
var urls;
layui.use(['form', 'layer'], function () {
    // 操作对象
    var form = layui.form
        , layer = layui.layer
        , $ = layui.jquery;
    
    $('#grage').val(0);	//初始加载默认好评
  //监听提交
    $("#postAdd").click(function(){
    	var content = $('#textarea').val();
    	if(content == ""){
    		layer.msg("提交内容不能为空");
    	}else{
	        $.ajax({
	            type: 'POST',
	            url: '#(ctxPath)/wmall/mobile/comment/comment',
	            data: $('#addForm').serialize(),
	            success : function(data){
	            	if(data.code=='0'){
	                	/* window.location.href = '#(ctxPath)/wmall/mobile/myCenter'; */
	                	window.history.go(-2);
	                }
	            }
	        });
    	}
        return false; //阻止表单跳转。如果需要表单跳转,去掉这段即可。
    });
  	//删除图片点击事件
    $(document).on('click','.button_img', function(obj) {
    	var url = $(this).prev().attr("src");
    	var newValue = $('#postImages').val().replace("|"+url,"").replace(url+"|","").replace(url,"");
    	document.getElementById('postImages').value = newValue;
    	var arryValue = $('#postImages').val().split("|");
    	$('#demo2').empty();
    	for (var i=0; i<arryValue.length; i++){
    		if(arryValue[i]!=""){
    			$('#demo2').append('<img src="'+ arryValue[i] +'" url="'+ arryValue[i] +'" class="layui-upload-img ">').append('<button   lay-submit lay-filter="*" class ="button_img delete"></button>')
    		}
    	}
    	if(arryValue.length<5){
    		$('#upload_img').show();
    	}
    });
    //增加好评点击事件
    $(document).on('click','.mui-control-item', function(obj) {
    	var grage = $(this).text();
    	switch(grage){
    	case "好评":
    		$('#grage').val(0);
    		break
    	case "中评":
    		$('#grage').val(1);
    		break
    	case "差评":
    		$('#grage').val(2);
    		break
    	}
    });
  
});
 

    layui.use('upload', function(){
   
在C#中,将多张图片保存到SQL Server的`VARBINARY(MAX)`或其他大容量二进制字段通常用于存储非结构化的图像数据。如果你需要将多张图片合并并存储在一起,可以采用以下步骤: 1. **图片合并**: 使用`System.IO.MemoryStream`类,你可以创建一个新的内存流来存储所有图片的数据。遍历每张图片,将其转换为字节数组并追加到内存流。 ```csharp byte[] combinedData; using (MemoryStream ms = new MemoryStream()) { foreach (var image in images) { byte[] imageData = Image.FromFile(image.Path).GetByteArray(); ms.Write(imageData, 0, imageData.Length); } combinedData = ms.ToArray(); } ``` 2. **插入数据库**: 将合并后的字节数组作为值,插入到SQL Server的相应字段中。 ```csharp string connectionString = "your_connection_string"; SqlCommand command = new SqlCommand( $"INSERT INTO your_table (combined_image) VALUES (@combinedImage)", connection); command.Parameters.AddWithValue("@combinedImage", SqlDbType.VarBinary).Value = combinedData; connection.ExecuteNonQuery(); ``` 3. **读取时拆分**: 当从数据库读取时,你需要先从字段中获取整个字节数组,然后逐块分离成单张图片。这可以通过循环读取并写入文件来实现。 ```csharp byte[] combinedImageFromDB = GetCombinedImageDataFromDatabase(); // 获取数据库中的图像数据 int bytesRead = 0; while (bytesRead < combinedImageFromDB.Length) { int dataSize = Math.Min(combinedImageFromDB.Length - bytesRead, bufferLength); // 分配合适的缓冲区大小 using (MemoryStream subStream = new MemoryStream(combinedImageFromDB, bytesRead, dataSize)) { byte[] bytesInSubStream = new byte[dataSize]; subStream.Read(bytesInSubStream, 0, dataSize); string imageName = GenerateUniqueFileName(); // 生成新图片的临时文件名 File.WriteAllBytes(imageName, bytesInSubStream); } bytesRead += dataSize; } // GenerateUniqueFileName() 函数负责生成唯一文件名,避免覆盖其他图片 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值