webapi 上传图片bitmap_c# webapi 上传图片图片 - CSDN
精华内容
参与话题
  • 项目中需要用到图片上传,昨天搞整了一下,对我这个菜鸟来说,还是有很多值得注意的地方。  h5+提供了可以调用原生安卓API的功能,当然也能调用camera。需要注意的是,拍照后的保存路径如果不自己设置的话,是...

         项目中需要用到图片上传,昨天搞整了一下,对我这个菜鸟来说,还是有很多值得注意的地方。

           h5+提供了可以调用原生安卓API的功能,当然也能调用camera。需要注意的是,拍照后的保存路径如果不自己设置的话,是使用的hbuilder默认的路径。不过,我把路径打印出来,在genymotion里面居然没有翻到。还有一点,通过h5+调用拍照后照片也不会保存到相册​,但是在真机上是会自动保存的,为了以防万一,可以设置图片保存到本地相册。不多说,贴代码。

    页面打开时需要在plus中预加载,这里新建文件夹camera

           plus.camera.getCamera返回摄像头管理对象,之后可以对拍照参数进行设置,拍照成功会调用回调函数。使用resolveLocalFileSystemURL可以通过URL参数获取目录对象或文件对象,把entry转换成本地路径之后就可以保存啦。

    拍摄照片

           通过相册选择照片的方式和获取摄像头的操作差不多,在这里我给了一个f1的全局数组变量。用来存放选择的照片。哦,单选的话就不用数组了可以。多选和单选,可以通过GalleryOptions对象来进行设置:multiple: true.还可以进行好多好多设置。

    相册选择照片

           好了现在可以进行图片上传了,在这里使用的是二进制流的形式进行上传,同时为了节约资源,有必要对图片进行压缩,这个代码我是扒的DCould论坛上面的。利用canvas对图片进行重绘,要压缩多小,修改w = 320 || w;的数字就行了,我这里是320,300多K的图片传到后台也就150K了。不过可以更小,最好注意按比例压缩。哦,这里是需要导入jquery.min.js的包的,attr是jquery下的方法,不然用不了。每次压缩完成之后,用push方法把图片流追加进数组就行了。

    压缩图片

           好了可以上传啦,上传利用的是mui封装的post方法,跟ajax其实是一样的。h5+其实提供了很多上传方法,比如有一个uploader的接口,也可用来上传,c#的话,可以用handler来接收,不过我不怎么熟悉,需要好好研究研究。

    上传

           接下来就是后台接收了,在这里使用的是mvc,前端直接请求action,返回图片数组,在转换成图片之前,base64的格式需要把开头一段去掉。不然会报格式错误的。在保存进文件夹的时候,之前代码老是报错:GDI+中发生一般性错误,就是这个。在网上搜索了好久,解决办法为克隆一个bitmap对象,同时Dispose来及时释放掉打开的文件(c#的话使用using{}来限定也可以),不过这个解决方法的应用场景为从文件夹读出然后写入。图片上传还用不到克隆bitmap,最后在我们老大的提示下终于发现,iis对文件夹的写入进行了限制,需要去开启权限,就是要把everyone的权限添加上去,同时还要赋予完全控制权限。这样就可以顺利进行文件写入的操作啦。

    c#后台接收

           贴一个克隆bitmap的方法,与这次的图片上传没啥关系,留着以后能用到。

    bitmap转换

    ​       最后,我还要感谢老大,以及其他小伙伴,在工作中给了我很多帮助,有这么一群小伙伴在一起真的太好啦!

    展开全文
  • android 上传Bitmap到服务器端

    万次阅读 2016-11-15 18:10:14
    转载于: Last week, I faced a problem to send an image to the server, I have tried a lot of ways, but seemed that nothing would work. After some research, I found the HTTPClient... API , this API hel

    Android拍照获取照片路径并上传至服务器+Servlet代码


    摘要: 拍照和选择本地图片上传的代码网上很多,但也有的代码在自己程序上跑不起来,所以整的有点尴尬,今天自己的拍照上传和本地图片选择上传代码都已完成。

    先来客户端代码【这里只写了主要代码】

    先来张效果图,

    
    
    iv_photo.setOnClickListener(new OnClickListener() {
    
    		@Override
    		public void onClick(View v) {
    			new ActionSheetDialog(SendGoodsDetailsActivity.this).builder().setTitle("上传车辆照片")
    						.setCancelable(false).setCanceledOnTouchOutside(false)
    						.addSheetItem("拍照上传", SheetItemColor.Blue, new OnSheetItemClickListener() {
    
    				@Override
    				public void onClick(int which) {
    					// 拍照
    					//设置图片的保存路径,作为全局变量
    					imageFilePath = Environment.getExternalStorageDirectory().getAbsolutePath()+"/filename.jpg";
    					File temp = new File(imageFilePath);		
    					Uri imageFileUri = Uri.fromFile(temp);//获取文件的Uri	 
    					Intent it = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);//跳转到相机Activity
    					it.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, imageFileUri);//告诉相机拍摄完毕输出图片到指定的Uri
    					 startActivityForResult(it, 102);
    				}
    				}).addSheetItem("相册选择", SheetItemColor.Blue, new OnSheetItemClickListener() {
    				@Override
    				public void onClick(int which) {
    					// 相册选取
    					Intent intent1 = new Intent(Intent.ACTION_GET_CONTENT);
    					intent1.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*");
    					startActivityForResult(intent1, 103);
    						}
    					}).show();
    				}
    			});
    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
    		switch(requestCode){
    		 case 102:
    			 if (resultCode == Activity.RESULT_OK) {
    				 
    				 Bitmap bmp = BitmapFactory.decodeFile(imageFilePath);  
    		                iv_photo.setImageBitmap(bmp);
    			 }
    		 break;
    		 case 103:
    			 Bitmap bm = null;
    			 // 外界的程序访问ContentProvider所提供数据 可以通过ContentResolver接口
    			 ContentResolver resolver = getContentResolver();
    
    			 try {
    				Uri originalUri = data.getData(); // 获得图片的uri
    
    				bm = MediaStore.Images.Media.getBitmap(resolver, originalUri); // 显得到bitmap图片
    
    				// 这里开始的第二部分,获取图片的路径:
    
    				String[] proj = { MediaStore.Images.Media.DATA };
    
    				// 好像是android多媒体数据库的封装接口,具体的看Android文档
    				@SuppressWarnings("deprecation")
    				Cursor cursor = managedQuery(originalUri, proj, null, null, null);
    				// 按我个人理解 这个是获得用户选择的图片的索引值
    				int column_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
    				// 将光标移至开头 ,这个很重要,不小心很容易引起越界
    				cursor.moveToFirst();
    				// 最后根据索引值获取图片路径
    				String path = cursor.getString(column_index);
    				iv_photo.setImageURI(originalUri);
    				
    			 } catch (IOException e) {
    				e.printStackTrace();
    			 }
    			 break;
    		 }
    		super.onActivityResult(requestCode,resultCode,data);
    }
    下面是上传的一个工具类,嘻嘻,从网上找的一个大神的,可以用
    /**
     * 
     * 上传工具类
     * @author spring sky
     * Email:vipa1888@163.com
     * QQ:840950105
     * MyName:石明政
     */
    public class UploadUtil {
        private static final String TAG = "uploadFile";
        private static final int TIME_OUT = 10*1000;   //超时时间
        private static final String CHARSET = "utf-8"; //设置编码
        /**
         * android上传文件到服务器
         * @param file  需要上传的文件
         * @param RequestURL  请求的rul
         * @return  返回响应的内容
         */
        public static String uploadFile(File file,String RequestURL){
            String result = null;
            String  BOUNDARY =  UUID.randomUUID().toString();  //边界标识   随机生成
            String PREFIX = "--" , LINE_END = "\r\n"; 
            String CONTENT_TYPE = "multipart/form-data";   //内容类型
            
            try {
                URL url = new URL(RequestURL);
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.setReadTimeout(TIME_OUT);
                conn.setConnectTimeout(TIME_OUT);
                conn.setDoInput(true);  //允许输入流
                conn.setDoOutput(true); //允许输出流
                conn.setUseCaches(false);  //不允许使用缓存
                conn.setRequestMethod("POST");  //请求方式
                conn.setRequestProperty("Charset", CHARSET);  //设置编码
                conn.setRequestProperty("connection", "keep-alive");   
                conn.setRequestProperty("Content-Type", CONTENT_TYPE + ";boundary=" + BOUNDARY); 
                conn.connect();
                
                if(file!=null){
                    /**
                     * 当文件不为空,把文件包装并且上传
                     */
                    DataOutputStream dos = new DataOutputStream( conn.getOutputStream());
                    StringBuffer sb = new StringBuffer();
                    sb.append(PREFIX);
                    sb.append(BOUNDARY);
                    sb.append(LINE_END);
                    /**
                     * 这里重点注意:
                     * name里面的值为服务器端需要key   只有这个key 才可以得到对应的文件
                     * filename是文件的名字,包含后缀名的   比如:abc.png  
                     */
                    
                    sb.append("Content-Disposition: form-data; name=\"img\"; filename=\""+file.getName()+"\""+LINE_END); 
                    sb.append("Content-Type: application/octet-stream; charset="+CHARSET+LINE_END);
                    sb.append(LINE_END);
                    dos.write(sb.toString().getBytes());
                    InputStream is = new FileInputStream(file);
                    byte[] bytes = new byte[1024];
                    int len = 0;
                    while((len=is.read(bytes))!=-1){
                        dos.write(bytes, 0, len);
                    }
                    is.close();
                    dos.write(LINE_END.getBytes());
                    byte[] end_data = (PREFIX+BOUNDARY+PREFIX+LINE_END).getBytes();
                    dos.write(end_data);
                    dos.flush();
                    /**
                     * 获取响应码  200=成功
                     * 当响应成功,获取响应的流  
                     */
                    int res = conn.getResponseCode();  
    	            if(res==200){
                        InputStream input =  conn.getInputStream();
                        StringBuffer sb1= new StringBuffer();
                        int ss ;
                        while((ss=input.read())!=-1){
                            sb1.append((char)ss);
                        }
                        result = sb1.toString();
                        System.out.println(result);
    	            }
                }
            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return result;
        }
    }
    在下就是调用上传的方法了,这里我给摘出来了
    File file = new File(path); //这里的path就是那个地址的全局变量
    							
    String result = UploadUtil.uploadFile(file, RequestURL);
    这里客户端就完成了,下面就是服务端代码,这里我用的是servlet
    public class UploadShipServlet extends HttpServlet {
    	private static final long serialVersionUID = 1L;
    	private String path;
    
    	public UploadShipServlet() {
    		super();
    	}
    
    	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		this.doPost(request, response);
    	}
    
    	protected void doPost(HttpServletRequest request, HttpServletResponse response)
    			throws ServletException, IOException {
    		response.setContentType("text/html;charset=utf-8");
    		request.setCharacterEncoding("utf-8");
    		response.setCharacterEncoding("utf-8");
    		PrintWriter out = response.getWriter();
    		
    		// 创建文件项目工厂对象
    		DiskFileItemFactory factory = new DiskFileItemFactory();
    
    		// 设置文件上传路径
    		String upload = this.getServletContext().getRealPath("/");
    		
    		// 获取系统默认的临时文件保存路径,该路径为Tomcat根目录下的temp文件夹
    		String temp = System.getProperty("java.io.tmpdir");
    		// 设置缓冲区大小为 5M
    		factory.setSizeThreshold(1024 * 1024 * 5);
    		// 设置临时文件夹为temp
    		factory.setRepository(new File(temp));
    		// 用工厂实例化上传组件,ServletFileUpload 用来解析文件上传请求
    		ServletFileUpload servletFileUpload = new ServletFileUpload(factory);
    
    		// 解析结果放在List中
    		try {
    			List<FileItem> list = servletFileUpload.parseRequest(request);
    
    			for (FileItem item : list) {
    				String name = item.getFieldName();
    				InputStream is = item.getInputStream();
    
    				if (name.contains("content")) {
    					System.out.println(inputStream2String(is));
    				} else if (name.contains("img")) {
    					try {
    						path = upload+"\\"+item.getName();
    						inputStream2File(is, path);
    						break;
    					} catch (Exception e) {
    						e.printStackTrace();
    					}
    				}
    			}
    			out.write(path);  //这里我把服务端成功后,返回给客户端的是上传成功后路径
    		} catch (FileUploadException e) {
    			e.printStackTrace();
    			System.out.println("failure");
    			out.write("failure");
    		}
    
    		out.flush();
    		out.close();
    	}
    
    	// 流转化成字符串
    	public static String inputStream2String(InputStream is) throws IOException {
    		ByteArrayOutputStream baos = new ByteArrayOutputStream();
    		int i = -1;
    		while ((i = is.read()) != -1) {
    			baos.write(i);
    		}
    		return baos.toString();
    	}
    
    	// 流转化成文件
    	public static void inputStream2File(InputStream is, String savePath) throws Exception {
    		System.out.println("文件保存路径为:" + savePath);
    		File file = new File(savePath);
    		InputStream inputSteam = is;
    		BufferedInputStream fis = new BufferedInputStream(inputSteam);
    		FileOutputStream fos = new FileOutputStream(file);
    		int f;
    		while ((f = fis.read()) != -1) {
    			fos.write(f);
    		}
    		fos.flush();
    		fos.close();
    		fis.close();
    		inputSteam.close();
    
    	}
    }


    ok了,这样就大功告成了,多整理以后好用得着。

    ======================================================================================

    Last week, I faced a problem to send an image to the server, I have tried a lot of ways, but seemed that nothing would work.

    After some research, I found the HTTPClient API , this API helped me to do the dirty work, and it did pretty well. I will show you now, how to upload images and/or strings to the web server.

    It’s pretty simple, actually. I gonna do in only one function!

     

    1. // create a bitmap variable before anything;  
    2.   
    3. private Bitmap bitmap;  
    4.   
    5. // variable to set a name to the image into SD card;  
    6. // this variable, you have to put the path for the File, It's up to you;  
    7.   
    8. public static String exsistingFileName;  
    9.   
    10. // sendData is the function name, to call it, you can use something like sendData(null);  
    11. // remember to wrap it into a try catch;  
    12.   
    13. public void sendData(String[] args) throws Exception {  
    14.     try {  
    15.   
    16.         HttpClient httpClient = new DefaultHttpClient();  
    17.         HttpContext localContext = new BasicHttpContext();  
    18.   
    19.         // here, change it to your php;  
    20.   
    21.         HttpPost httpPost = new HttpPost("http://www.myURL.com/myPHP.php");  
    22.         MultipartEntity entity = new MultipartEntity(HttpMultipartMode.BROWSER_COMPATIBLE);  
    23.         bitmap = BitmapFactory.decodeFile(exsistingFileName);  
    24.   
    25.         // you can change the format of you image compressed for what do you want;  
    26.         //now it is set up to 640 x 480;  
    27.   
    28.         Bitmap bmpCompressed = Bitmap.createScaledBitmap(bitmap, 640480true);  
    29.         ByteArrayOutputStream bos = new ByteArrayOutputStream();  
    30.   
    31.         // CompressFormat set up to JPG, you can change to PNG or whatever you want;  
    32.   
    33.         bmpCompressed.compress(CompressFormat.JPEG, 100, bos);  
    34.         byte[] data = bos.toByteArray();  
    35.   
    36.         // sending a String param;  
    37.   
    38.         entity.addPart("myParam"new StringBody("my value"));  
    39.   
    40.         // sending a Image;  
    41.         // note here, that you can send more than one image, just add another param, same rule to the String;  
    42.   
    43.         entity.addPart("myImage"new ByteArrayBody(data, "temp.jpg"));  
    44.   
    45.         httpPost.setEntity(entity);  
    46.         HttpResponse response = httpClient.execute(httpPost, localContext);  
    47.         BufferedReader reader = new BufferedReader(new InputStreamReader( response.getEntity().getContent(), "UTF-8"));  
    48.         String sResponse = reader.readLine();  
    49.   
    50.     } catch (Exception e) {  
    51.   
    52.         Log.v("myApp""Some error came up");  
    53.   
    54.     }  
    55.   
    56. }  
    展开全文
  • C# 图片旋转和获取原图片旋转角度

    千次阅读 2015-12-16 21:09:00
    调用: protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string path = @"C:\Users\wangbinbin\Desktop\WebApi和AccessWebApi两个

            /// <summary>
            /// 获取原图旋转角度(IOS和Android相机拍的照片)
            /// </summary>
            /// <param name="path"></param>
            /// <returns></returns>
            public static int readPictureDegree(string path)
            {
                int rotate = 0;
                using (var image = System.Drawing.Image.FromFile(path))
                {
                    foreach (var prop in image.PropertyItems)
                    {
                        if (prop.Id == 0x112)
                        {
                            if (prop.Value[0] == 6)
                                rotate = 90;
                            if (prop.Value[0] == 8)
                                rotate = -90;
                            if (prop.Value[0] == 3)
                                rotate = 180;
                            prop.Value[0] = 1;
                        }
                    }
                }
                return rotate;
            }
    
            /// <summary>
            /// 旋转
            /// </summary>
            /// <param name="path"></param>
            /// <param name="rotateFlipType"></param>
            /// <returns></returns>
            public bool KiRotate(string path, RotateFlipType rotateFlipType)
            {
                try
                {
                    using (Bitmap bitmap = new Bitmap(path))
                    {
                        bitmap.RotateFlip(rotateFlipType);
                        bitmap.Save(path);
                    }
                    return true;
                }
                catch(Exception ex)
                {
                    return false;
                }
            }

    解释:
    顺时针旋转90度 RotateFlipType.Rotate90FlipNone
    逆时针旋转90度 RotateFlipType.Rotate270FlipNone

    水平翻转 RotateFlipType.Rotate180FlipY

    垂直翻转 RotateFlipType.Rotate180FlipX


    调用:

            protected void Page_Load(object sender, EventArgs e)
            {
                if (!IsPostBack)
                {
                    string path = @"C:\Users\wangbinbin\Desktop\WebApi和AccessWebApi两个项目(包含图片和文件上传)\AccessWebApi\AccessWebApi\images\25b3452f161450251612829203.jpg";
                    int rotate=readPictureDegree(path);
                    if (rotate == 90)
                    {
                        KiRotate(path, RotateFlipType.Rotate90FlipNone);
                    }
                    else if (rotate == -90)
                    {
                        KiRotate(path, RotateFlipType.Rotate270FlipNone);
                    }
                    else if (rotate == 180)
                    {
                        KiRotate(path, RotateFlipType.Rotate180FlipNone);
                    }
                }
            }


    展开全文
  • 哎个人意见是将图片上传到服务器端,将图片资源保存保存到服务器端的磁盘上,数据库存储的只是图片在服务端的路径。。。。但。哎~~官大一级压死人啊。。没办法呗~~只好动脑找资料,经过一天的奋斗终于把这问题给解决...

    我们项目组的组长居然要将图片转成二进制流存到数据库内~~。。。我去。。。极度不赞同啊。哎个人意见是将图片上传到服务器端,将图片资源保存保存到服务器端的磁盘上,数据库存储的只是图片在服务端的路径。。。。但。哎~~官大一级压死人啊。。没办法呗~~只好动脑找资料,经过一天的奋斗终于把这问题给解决咯~~呵呵呵

    我的思路是将图片转成二进制流byte[],再将byte[]转成String类型的字符串,然后利用流将其传输。

    好了 不多说咯 上代码。

    首先在web端的servlet内

    public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
    response.setContentType("text/html;charset=UTF-8");
    FileInputStream fis=new FileInputStream("F:/古典美女/haha.jpg");
    ByteArrayOutputStream baos=new ByteArrayOutputStream();
    byte[] buffer=new byte[1024];
    int count=0;
    while((count=fis.read(buffer))>=0){
    baos.write(buffer);
    }
    String str=new String(Base64.encode(baos.toByteArray()));
    PrintWriter pw=response.getWriter();
    pw.write(str);
    pw.flush();
    pw.close();
    }

    这部分的代码位于web端的servlet的doPost方法内。。我这里为了简约。。没有连接数据库得到图片的二进制流,而是用本地的一张图片将其转为二进制数组,将其传到android端。。道理都是一样的。。呵呵呵呵呵。

    最值得注意的是:String str=new String(Base64.encode(baos.toByteArray()));这句代码,利用Base64的编码类的静态方法encode将一个byte[]转成String类型的对象

    注意。。尽管byte[]也有一个toString的方法可以将byte[]转成String,但貌似这个方法存在弊端。会存在数据丢失和乱码(我试过了。。不知道你们会怎样。。)然后用PrintWriter写出去。。。。。

    好了 web端的代码就这么多

    关键是android端的代码。ok!!! 上代码

    先说明.android端的AndroidManifest.xml文件要添加<uses-permission android:name="android.permission.INTERNET"/>权限

    private ImageView image=null;
    public static String path="http://10.0.2.2:8080/ConnDB/NewServlet";
    private String result="";

    先在activity内声明三个变量。

    在OnCreate()内

    public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.main);
            image=(ImageView) findViewById(R.id.image);
            showImage();
        }

    好了 来看看showImage方法内的代码

    public void showImage(){
         HttpGet request=new HttpGet(path);
    try {
    //使用response接收servlet返回的数据
    HttpResponse response=new DefaultHttpClient().execute(request);
    //判断servlet是否返回成功
    if(response.getStatusLine().getStatusCode()==200){
    HttpEntity entity=response.getEntity();
    BufferedReader br=new BufferedReader(new InputStreamReader
    (entity.getContent(),"UTF-8"));
    String line="";
    while((line=br.readLine())!=null){
    result=result+line;
    }
    System.out.println(result);
    if(!result.equals("")){
    Bitmap bitmap=ConnTestActivity.getBitmapFromByte(result);
    image.setImageBitmap(bitmap);
    }
    }
    }catch(Exception e){
    e.printStackTrace();
    }
    result="";
        }

    这里通过传过来的String生成byte[],在用其生成一个Bitmap对象,在设置在ImageView内 将其显示

    Bitmap bitmap=ConnTestActivity.getBitmapFromByte(result);
    image.setImageBitmap(bitmap);

    下面来看看getBitmapFromByte(result);方法

    public static Bitmap getBitmapFromByte(String str){
         if(str==null){
         return null;
         }
         Bitmap bitmap=null;
    byte[] bytes = Base64.decode(str);
    bitmap=BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
    return bitmap;
        }

    byte[] bytes = Base64.decode(str);这句代码的作用于web端的作用相反,将Streing转换成byte[]。。。。。

    好了 代码写到这里咯。。。。接下来就是运行了

    运行android模拟器将会显示


    不过这里有点小小的问题。。。就是Base64这个类。。。。

    Base64这个类原本并不属于java官方类的api,尽管在java文件中可以使用这个类。。但在android使用的话却会报错。。。就是这一点搞得我很头痛 。。结果实在没办法,只好上网找别人写好的编码类。。将其变成一个class类放到项目中使用。ok 问题解决。。。。。。


    如果有人需要这个编码类的话 可以到我的空间下载 我会上传上去的 。。。你也可以上网自己找。。呵呵呵呵呵

    Base64.java的连接:http://download.csdn.net/my/uploads

    展开全文
  • using System; using System.Collections.Generic; using System.Drawing; using System.IO; using System.Linq; using System.Net; using System.Net.Http...using System.Runtime.Serialization.Formatters.Binary...
  • 这几天我在做项目的时候就遇到了,在用webapi中做上传图片和MVC和一般处理程序还不一样,后台老是拿不到前台传递的数据,之前用一般处理程序和MVC就没遇到这种情况,经过几天的查询资料,今天终于实现了,利用的是...
  • ... 勾选不校验合法域名、web-view、TLS版本以及HTTPS证书 ...,并且在手机微信扫码...调试出现此问题是在微信小程序端选择图片上传到服务端后台时出现的, 微信小程序所在路径为 E:\WGY\微信小程序\FaultPatrol...
  • 今天来说说h5上传头像的问题吧。网上有很多的解决方案,开始我觉得好像很简单,都有成功案例,等把代码copy下来,发现并不能运行成功,真是一脸懵逼...N脸懵逼。 先说说为什么别人的代码都说测试通过了而在我这里都...
  • 解决微信公众平台IP白名单

    万次阅读 2017-12-02 08:05:47
    微信公众平台,作为自媒体的旗舰级产品,越来越多的人已经投入它的怀抱。正如它的广告词所说:再小的个体,也有品牌 好吧,闲话不多说,今天要说的是它的IP白名单机制。
  • 阿里云 OCR身份证识别Api 使用(一)

    万次阅读 2017-05-09 15:19:40
    首选OCR 识别技术,需要调用摄像头拍照上传。 使用照相技术我会单独写一篇学习笔记,照相camera 值得深究探讨。我这里就贴出简单的压缩图像代码。也是我写的demo里的一个小代码。 这里使用照相保存本
  • 百度地图API是为开发者免费提供的一套基于百度地图服务的应用接口,包括JavaScript APIWeb服务API、Android SDK、iOS SDK、定位SDK、车联网API、LBS云等多种开发工具与服务,提供基本地图展现、搜索、定位、逆/...
  • 最近参加腾讯的高校微信小程序大赛,用C#做过几个网站,便用C#做后台写接口,在操作的过程中遇到了很多问题。由于C#的生态(C#是最好的语言,不接受反驳),网上...一、图片文件上传 1.1基本上传代码 刚开开始做...
  • 在做网站开发时,我常常会做一些这样的工作:一张大图中包含了许多的小图,而网站中为了使用其中一张小图我不得不把大图切成一张张的小图。虽然这样的工作不多;...所以有了今天的服务器端剪切压缩图片的一章。
  • Android 快速开发框架:推荐10个框架

    万次阅读 多人点赞 2019-05-08 15:19:47
    一、Afinal 官方介绍: Afinal是一个Android的ioc,orm框架,内置了四大模块功能:FinalAcitivity,Final...通过finalBitmap,我们可以方便的加载bitmap图片,而无需考虑oom等问题。通过finalDB模块,我们一行代码...
  • Retrofit2实现图片文字上传

    万次阅读 热门讨论 2019-12-02 21:53:49
    3.1、创建RetrofitManager和APIService 3.2、准备好选择的图片 3.3、开始构造参数 3.4、实现上传 附:UploadHelper.java源码 前言 距离上一篇文章到现在已经有将近半年的时间了,因为换了一座城市,到现在才...
  • Android常用的框架有哪些

    万次阅读 2016-10-10 16:17:02
    1、volley ... (1) JSON,图像等的异步下载; (2) 网络请求的排序(scheduling) (3) 网络请求的优先级处理 (4) 缓存 (5) 多级别取消请求 (6) 和Activity和生命周期的联动(Activity结束时同时取消所有网络请求...
  • face++人脸识别接口实现原理(一)

    万次阅读 多人点赞 2019-01-18 11:56:31
    背景:市面上,能够提供人脸识别解决方案的公司主要有,百度,科大讯飞,旷世face++,还有已经被facebook收购的face.com。这里涉及到的是旷世科技的人脸识别技术。旷世科技人脸识别技术,在国内得到了很广泛运用,...
  • H5调用手机的摄像头拍照上传以及手机相册选取照片语法: *|video/*|image/*|MIME_type">提示:如需规定多个值,请使用逗号分隔(比如 )。 详情访问:w3c 使用步骤:*" type="file">目前支持情况是比较良好的...
  • 对于Android初学者以及对于我们菜鸟,这些大神们开发的轻量级框架非常有用(更别说开源的了)。...Afinal是一个android的ioc,orm框架,内置了四大模块功能:FinalAcitivity,FinalBitmap,FinalDb,FinalHttp。通过fi
  • Android 开发之多种方案PDF阅读

    万次阅读 2018-07-11 10:13:22
    Android 开发之多种方案PDF阅读 最近开发中涉及到阅读港股公告,但是HK股票的公告都是坑,居然是pdf的,所以没办法,就要研究安卓pdf阅读,期间踩了点坑...... 安卓的webview与ios 的UIWebView不一样,不能够支持...
1 2 3 4 5 ... 20
收藏数 3,333
精华内容 1,333
关键字:

webapi 上传图片bitmap