- 浏览: 5825369 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
快速迭代用
用法,伪代码:
简化从相册或照相获取图片的Android库:EasyImage
http://www.open-open.com/lib/view/open1446710908670.html
另一个Android图片(视频)选择器:android-media-picker
http://www.open-open.com/lib/view/open1437054095193.html
[多文件上传一]利用httpmime.jar实现
http://my.oschina.net/oppo4545/blog/315420
[多文件上传二]利用表单方式实现
http://my.oschina.net/oppo4545/blog/315441
[多文件上传三]利用UrlEncodedFormEntity表单实现
http://my.oschina.net/oppo4545/blog/315451
使用volley上传图片,一个参数多张图、多张图片多张图,亲测有效哦
http://m.blog.csdn.net/blog/chequer_lkp/40631271
一个图片裁减库,可以自定义UI,非常不错。
http://www.jcodecraeer.com/a/opensource/2015/0822/3343.html
图片剪切库:scissors
http://www.open-open.com/lib/view/open1448373865642.html
一个volley自定义请求支持文件上传:MultipartRequest
http://www.open-open.com/lib/view/open1442817196732.html
import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.Timer; import java.util.TimerTask; import org.json.JSONException; import org.json.JSONObject; import android.annotation.SuppressLint; import android.app.Activity; import android.app.AlertDialog; import android.content.ContentUris; import android.content.Context; import android.content.DialogInterface; import android.content.Intent; import android.database.Cursor; import android.graphics.Bitmap; import android.net.Uri; import android.os.Build; import android.os.Bundle; import android.os.Environment; import android.os.Handler; import android.os.Message; import android.provider.DocumentsContract; import android.provider.MediaStore; import android.util.Log; import com.yirui.youbao.App; import com.yirui.youbao.net.Commands; /** * * @author pythoner * */ public class FaceUtil { private String[] items = new String[] { "图库", "拍照" }; /* 头像名称 */ private static final String IMAGE_FILE_NAME = "faces.jpg"; /* 请求码 */ private static final int IMAGE_REQUEST_CODE = 0; private static final int SELECT_PIC_KITKAT = 3; private static final int CAMERA_REQUEST_CODE = 1; private static final int RESULT_REQUEST_CODE = 2; private Activity context; private final int ST_UPLOAD_SUCCESS=0; private final int ST_UPLOAD_FAIL=1; Handler handler = new Handler(){ public void handleMessage(Message msg) { super.handleMessage(msg); switch (msg.what) { case ST_UPLOAD_SUCCESS: if (onFaceUploadListener != null) { DataWrap datas=(DataWrap)msg.obj; try { JSONObject response = new JSONObject(datas.data); JSONObject result = response.optJSONObject("result"); int code = result.optInt("code"); if (code == 2000) { JSONObject data = response.optJSONObject("data"); JSONObject urls = data.optJSONObject("urls"); String orignUrl = urls.optString("origin", null); String imgUrl = urls.optString("100_100", null); String circleImgUrl = urls.optString("100_100_circle", null); onFaceUploadListener.onFaceUploadSuccess(datas.photo, orignUrl,imgUrl, circleImgUrl); }else{ onFaceUploadListener.onFaceUploadFailed(datas.photo); } } catch (JSONException e) { // TODO Auto-generated catch block e.printStackTrace(); onFaceUploadListener.onFaceUploadFailed(datas.photo); } } break; case ST_UPLOAD_FAIL: if (onFaceUploadListener != null) { DataWrap datas=(DataWrap)msg.obj; onFaceUploadListener.onFaceUploadFailed(datas.photo); } break; default: break; } } }; public FaceUtil(Activity context) { this.context = context; } public void showSettingFaceDialog() { new AlertDialog.Builder(context) .setTitle("图片来源") .setCancelable(true) .setItems(items, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { switch (which) { case 0:// Local Image Intent intent = new Intent( Intent.ACTION_GET_CONTENT); intent.addCategory(Intent.CATEGORY_OPENABLE); intent.setType("image/*"); if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.KITKAT) { context.startActivityForResult(intent, SELECT_PIC_KITKAT); } else { context.startActivityForResult(intent, IMAGE_REQUEST_CODE); } break; case 1:// Take Picture Intent intentFromCapture = new Intent( MediaStore.ACTION_IMAGE_CAPTURE); // 判断存储卡是否可以用,可用进行存储 if (hasSdcard()) { intentFromCapture.putExtra( MediaStore.EXTRA_OUTPUT, Uri.fromFile(new File(Environment .getExternalStorageDirectory(), IMAGE_FILE_NAME))); } context.startActivityForResult(intentFromCapture, CAMERA_REQUEST_CODE); break; } } }) .setNegativeButton("取消", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { dialog.dismiss(); } }).show(); } public void onActivityResult(int requestCode, int resultCode, Intent data) { // 结果码不等于取消时候 if (resultCode != Activity.RESULT_CANCELED) { switch (requestCode) { case FaceUtil.IMAGE_REQUEST_CODE: startPhotoZoom(data.getData()); break; case FaceUtil.SELECT_PIC_KITKAT: startPhotoZoom(data.getData()); break; case FaceUtil.CAMERA_REQUEST_CODE: File tempFile = new File( Environment.getExternalStorageDirectory(), FaceUtil.IMAGE_FILE_NAME); if (tempFile.exists()) { startPhotoZoom(Uri.fromFile(tempFile)); } break; case FaceUtil.RESULT_REQUEST_CODE: if (data != null) { setData(data); } break; } } } private boolean hasSdcard() { return Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED); } /** * 裁剪图片方法实现 * * @param uri */ private void startPhotoZoom(Uri uri) { if (uri == null) { Log.i("tag", "The uri is not exist."); return; } Intent intent = new Intent("com.android.camera.action.CROP"); if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.KITKAT) { String url = getPath(context, uri); intent.setDataAndType(Uri.fromFile(new File(url)), "image/*"); } else { intent.setDataAndType(uri, "image/*"); } // 设置裁剪 intent.putExtra("crop", "true"); // aspectX aspectY 是宽高的比例 intent.putExtra("aspectX", 1); intent.putExtra("aspectY", 1); // outputX outputY 是裁剪图片宽高 intent.putExtra("outputX", 200); intent.putExtra("outputY", 200); intent.putExtra("return-data", true); context.startActivityForResult(intent, RESULT_REQUEST_CODE); } /** * 保存裁剪之后的图片数据 * * @param picdata */ private void setData(Intent data) { Bundle extras = data.getExtras(); if (extras != null) { Bitmap photo = extras.getParcelable("data"); if (photo != null) { //这里是保存图片到本地 saveBitmap(photo); //然后上传图片到服务端保存; //此处每个人实现是不一样的,一般需要重写uploadFace方法; //我这里没有抽成接口,为了快速迭代使用; //但是,我在uploadFace成功后回调onFaceUploadSuccess方法; uploadFace(photo); } } } private OnFaceUploadListener onFaceUploadListener; public void setOnFaceUploadListener( OnFaceUploadListener onFaceUploadListener) { this.onFaceUploadListener = onFaceUploadListener; } public interface OnFaceUploadListener { void onFaceUploadSuccess(Bitmap photo, String orignUrl, String imgUrl, String circleImgUrl); void onFaceUploadFailed(Bitmap photo); } private void saveBitmap(Bitmap bitmap) { File f = new File(Environment.getExternalStorageDirectory(), IMAGE_FILE_NAME); try { f.createNewFile(); FileOutputStream fos = null; fos = new FileOutputStream(f); bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos); fos.flush(); fos.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } private void uploadFace(final Bitmap photo) { TimerTask task=new TimerTask() { @Override public void run() { // TODO Auto-generated method stub File file = new File(Environment.getExternalStorageDirectory(),IMAGE_FILE_NAME); String filePath = file.getAbsolutePath(); String urlString=Commands.URL_SYSTEMS_UPLOAD_FILE+"?user_session_key="+App.user.getUser_session_key()+"&file_category=1"; uploadFile(photo,filePath,urlString); } }; Timer t=new Timer(); t.schedule(task, 5); //使用volley上传,该方法可能会报错 /*Commands.uploadFile(context, 1, App.user, filePath, new VolleyHelper.OnFileUploadListener() { @Override public void onFileUploadSuccess(String orignUrl, String imgUrl, String circleImgUrl) { // TODO Auto-generated method stub if (onFaceUploadSuccessListener != null) { onFaceUploadSuccessListener .onFaceUploadSuccess(view, photo, orignUrl, imgUrl, circleImgUrl); } } });*/ } /** * 上传文件至Server * @param photo * @param filePath 文件路径 * @param urlString 连接地址 */ private void uploadFile(Bitmap photo,String filePath,String urlString) { String end ="\r\n"; String twoHyphens ="--"; String boundary ="*****"; try { URL url =new URL(urlString); HttpURLConnection con=(HttpURLConnection)url.openConnection(); con.setDoInput(true); con.setDoOutput(true); con.setUseCaches(false); con.setRequestMethod("POST"); con.setRequestProperty("Connection", "Keep-Alive"); con.setRequestProperty("Charset", "UTF-8"); con.setRequestProperty("Content-Type", "multipart/form-data;boundary="+boundary); DataOutputStream dos =new DataOutputStream(con.getOutputStream()); dos.writeBytes(twoHyphens + boundary + end); dos.writeBytes("Content-Disposition: form-data; "+"name=\"file1\";filename=\""+IMAGE_FILE_NAME +"\""+ end); dos.writeBytes(end); FileInputStream fis =new FileInputStream(filePath); int bufferSize =1024; byte[] buffer =new byte[bufferSize]; int length =-1; /* 从文件读取数据至缓冲区 */ while((length = fis.read(buffer)) !=-1) { dos.write(buffer, 0, length); } dos.writeBytes(end); dos.writeBytes(twoHyphens + boundary + twoHyphens + end); dos.flush(); dos.close(); fis.close(); /* 取得Response内容 */ InputStream is = con.getInputStream(); int ch; StringBuffer b =new StringBuffer(); while( ( ch = is.read() ) !=-1 ) { b.append( (char)ch ); } is.close(); DataWrap obj=new DataWrap(photo,b.toString()); sendMessage(ST_UPLOAD_SUCCESS,obj); } catch(Exception e) { e.printStackTrace(); DataWrap obj=new DataWrap(photo,null); sendMessage(ST_UPLOAD_FAIL,obj); } } private void sendMessage(int st,Object obj){ Message message = new Message(); message.what = st; message.obj=obj; handler.sendMessage(message); } class DataWrap{ Bitmap photo; String data; DataWrap(Bitmap photo,String data){ this.photo=photo; this.data=data; } } @SuppressLint("NewApi") private static String getPath(final Context context, final Uri uri) { final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT; // DocumentProvider if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) { // ExternalStorageProvider if (isExternalStorageDocument(uri)) { final String docId = DocumentsContract.getDocumentId(uri); final String[] split = docId.split(":"); final String type = split[0]; if ("primary".equalsIgnoreCase(type)) { return Environment.getExternalStorageDirectory() + "/" + split[1]; } } // DownloadsProvider else if (isDownloadsDocument(uri)) { final String id = DocumentsContract.getDocumentId(uri); final Uri contentUri = ContentUris.withAppendedId( Uri.parse("content://downloads/public_downloads"), Long.valueOf(id)); return getDataColumn(context, contentUri, null, null); } // MediaProvider else if (isMediaDocument(uri)) { final String docId = DocumentsContract.getDocumentId(uri); final String[] split = docId.split(":"); final String type = split[0]; Uri contentUri = null; if ("image".equals(type)) { contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI; } else if ("video".equals(type)) { contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI; } else if ("audio".equals(type)) { contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; } final String selection = "_id=?"; final String[] selectionArgs = new String[] { split[1] }; return getDataColumn(context, contentUri, selection, selectionArgs); } } // MediaStore (and general) else if ("content".equalsIgnoreCase(uri.getScheme())) { // Return the remote address if (isGooglePhotosUri(uri)) return uri.getLastPathSegment(); return getDataColumn(context, uri, null, null); } // File else if ("file".equalsIgnoreCase(uri.getScheme())) { return uri.getPath(); } return null; } /** * Get the value of the data column for this Uri. This is useful for * MediaStore Uris, and other file-based ContentProviders. * * @param context * The context. * @param uri * The Uri to query. * @param selection * (Optional) Filter used in the query. * @param selectionArgs * (Optional) Selection arguments used in the query. * @return The value of the _data column, which is typically a file path. */ private static String getDataColumn(Context context, Uri uri, String selection, String[] selectionArgs) { Cursor cursor = null; final String column = "_data"; final String[] projection = { column }; try { cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs, null); if (cursor != null && cursor.moveToFirst()) { final int index = cursor.getColumnIndexOrThrow(column); return cursor.getString(index); } } finally { if (cursor != null) cursor.close(); } return null; } /** * @param uri * The Uri to check. * @return Whether the Uri authority is ExternalStorageProvider. */ private static boolean isExternalStorageDocument(Uri uri) { return "com.android.externalstorage.documents".equals(uri .getAuthority()); } /** * @param uri * The Uri to check. * @return Whether the Uri authority is DownloadsProvider. */ private static boolean isDownloadsDocument(Uri uri) { return "com.android.providers.downloads.documents".equals(uri .getAuthority()); } /** * @param uri * The Uri to check. * @return Whether the Uri authority is MediaProvider. */ private static boolean isMediaDocument(Uri uri) { return "com.android.providers.media.documents".equals(uri .getAuthority()); } /** * @param uri * The Uri to check. * @return Whether the Uri authority is Google Photos. */ private static boolean isGooglePhotosUri(Uri uri) { return "com.google.android.apps.photos.content".equals(uri .getAuthority()); } }
用法,伪代码:
ImageView iv_face = (ImageView) view.findViewById(R.id.iv_face); iv_face.setOnClickListener(this); //初始化显示默认头像 Bitmap defaultFace = ImageUtil.drawableToBitmap(App.res.getDrawable(R.drawable.default_face)); CircleImageDrawable drawable=new CircleImageDrawable(defaultFace); iv_face.setImageDrawable(drawable); faceUtil =new FaceUtil(this,iv_face); faceUtil.setOnFaceUploadSuccessListener(new FaceUtil.OnFaceUploadSuccessListener() { @Override public void onFaceUploadSuccess(ImageView view, Bitmap photo, String orignUrl, String imgUrl, String circleImgUrl) { // TODO Auto-generated method stub Log.i("tag", "orignUrl=" + orignUrl); Log.i("tag", "imgUrl=" + imgUrl); Log.i("tag", "circleImgUrl=" + circleImgUrl); CircleImageDrawable drawable=new CircleImageDrawable(photo); view.setImageDrawable(drawable); App.user.setFaceUrl(orignUrl); App.user.setFaceBitmap(photo); } }); @Override public void onClick(View v) { // TODO Auto-generated method stub Intent intent=null; switch (v.getId()) { case R.id.iv_face: if(App.user.isLogined()){ faceUtil.showSettingFaceDialog(); }else{ intent=new Intent(context,UserLoginActivity.class); startActivity(intent); } break; } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); Log.i("tag", "requestCode==" + requestCode + ";resultCode==" + resultCode); faceUtil.onActivityResult(requestCode,resultCode,data); }
简化从相册或照相获取图片的Android库:EasyImage
http://www.open-open.com/lib/view/open1446710908670.html
另一个Android图片(视频)选择器:android-media-picker
http://www.open-open.com/lib/view/open1437054095193.html
[多文件上传一]利用httpmime.jar实现
http://my.oschina.net/oppo4545/blog/315420
[多文件上传二]利用表单方式实现
http://my.oschina.net/oppo4545/blog/315441
[多文件上传三]利用UrlEncodedFormEntity表单实现
http://my.oschina.net/oppo4545/blog/315451
使用volley上传图片,一个参数多张图、多张图片多张图,亲测有效哦
http://m.blog.csdn.net/blog/chequer_lkp/40631271
一个图片裁减库,可以自定义UI,非常不错。
http://www.jcodecraeer.com/a/opensource/2015/0822/3343.html
图片剪切库:scissors
http://www.open-open.com/lib/view/open1448373865642.html
一个volley自定义请求支持文件上传:MultipartRequest
http://www.open-open.com/lib/view/open1442817196732.html
发表评论
-
工具类之FragmentUtils
2017-04-01 11:37 1732fragment应该是广大Android开发者都用到过的一个v ... -
左中右结构的行布局
2016-12-19 21:35 1186最近项目要开发一个新版本,发现项目中许多布局大致都相同改动不大 ... -
RecyclerView:带header&footer&加载更多
2015-09-09 16:24 2970接上一篇 由简到繁,循序渐进 实现了: 0,点击&长按 ... -
RecyclerView:带header和footer的grid
2015-09-09 13:47 3048知道原理后,为RecyclerView实现同时带header和 ... -
RecyclerView:带header的grid
2015-09-09 13:01 2433RecyclerView是一个高度可定制性的View 本文将使 ... -
iconify使用文本替换icon测试
2015-08-28 17:12 1694源项目地址 https://github.com/JoanZa ... -
HorizontalScrollView+RadioGroup+ViewPager+FragmentPagerAdapter基本结构
2015-07-12 13:56 3298快速迭代用 import java.util.Arr ... -
LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构
2015-07-12 13:07 4158一切为了快速迭代 import java.util. ... -
RadioButton+ViewPager+FragmentPagerAdapter快速搭建页面结构
2015-07-12 11:08 2566一切为了快速开发 开发类似界面 import and ... -
为ViewPager设置CirclePageIndicator(小圆点)
2015-07-03 16:54 15336一切为了快速迭代! import android.con ... -
简单实现可以多选的ProductListDialog<T>
2015-06-25 22:33 1260只是一个范例,是为了代码快速迭代而写的 使用了listView ... -
基于上一篇写的SimplePairListPopupWindow<F,S>
2015-06-19 11:15 1539这次使用Pair<F,S>实现一个简单的Simpl ... -
基于上一篇实现的SimpleListPopupWindow<T>
2015-06-19 11:11 1521这次是个简单的PopupWindow,快速迭代用。 imp ... -
实现一个快速简单的SimpleListDialog<T>
2015-06-19 10:59 1750我写这样的文章都是为了快速迭代,所以都写的比较简单,谅解 此 ... -
为ViewPager设置SimpleViewPagerIndicator
2015-02-14 13:45 4729说到ViewPagerIndicator,网上有很多专门的开源 ... -
一个典型的从下部弹上来的Dialog
2014-12-05 14:47 6078典型的看图 import android.app ...
相关推荐
java udp 客户端和服务端工具类 java udp 客户端和服务端工具类 java udp 客户端和服务端工具类
在IT行业中,模拟服务端工具是非常重要的一环,特别是在软件开发和测试阶段。"模拟服务端工具.rar" 提供了一种便捷的方式,可以模拟TCP和UDP协议的服务端,以接收和处理数据。这样的工具对于开发者来说是宝贵的资源...
FTP(File Transfer Protocol)服务端工具是用于在互联网上实现文件传输的重要软件,尤其在Windows平台上广泛应用。FTP服务器允许用户从远程位置上传、下载文件,为数据共享和协作提供了便捷的途径。本压缩包文件...
总的来说,《石器时代服务端工具全集》是一款强大的辅助工具,它将游戏的管理权限交到了用户手中,让《石器时代》的世界更加鲜活、多变。无论是为了提升游戏体验,还是为了打造独一无二的游戏世界,这套工具都值得每...
8UFTP工具分为8UFTP客户端工具和 8UFTP智能扩展服务端工具,涵盖其它FTP工具所有的功能。不占内存,体积小,多线程,支持在线解压缩。界面友好,操作简单,可以管理多个ftp站点,使用拖拉即可完成文件或文件夹的上传、...
极光推送时,我们自己的后台推送消息时调用的方法。可配合http://blog.csdn.net/gengbaolong/article/details/77198565查看。
它可以在命令行下快速搭建临时的服务端或客户端,非常适合进行网络调试和测试。 另一个常见的工具是`telnet`,它可以模拟TCP客户端,连接到指定的服务器并发送数据。虽然现在更多地被SSH(安全外壳协议)取代,但在...
在Android应用开发中,用户可能需要通过拍照或从图库选择照片来设置头像,这一过程涉及到了多个关键步骤,包括请求系统权限、启动相机、访问图库、图像裁剪、图片压缩以及文件上传到服务器。以下是这个过程的详细...
本文将深入探讨如何实现一个完整的Android头像上传功能,包括客户端的实现以及服务端的处理。 首先,客户端(即Android应用)部分的实现主要涉及以下几个关键步骤: 1. **获取头像**: 用户可以通过选择本地照片或...
红月服务端管理工具rmtoolsVcngr
"千年服务端设置工具"则是一个使用易语言编写的专门用于配置和管理服务端的工具。在这款工具的帮助下,开发者或系统管理员可以更方便地对服务器进行设置和管理。 首先,我们要理解什么是服务端。服务端,也被称为...
总的来说,TCP客户端和服务端调试工具是开发过程中不可或缺的辅助工具,它们可以帮助开发者快速定位和解决问题,提高工作效率。“网络调试助手”以其强大的功能和易用性,成为许多开发者首选的TCP调试工具。在实际...
1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端综合Vick编辑工具1.03H服务端...
java服务器用的json工具类,自己封装的,支持beanToJson ListToJson arrayToJson等
61850服务端模拟工具是电力自动化领域中一种重要的软件工具,它主要用于测试和验证遵循IEC 61850标准的设备或系统。IEC 61850是国际电工委员会制定的一套通信协议,专门用于电力系统自动化,包括变电站自动化、馈线...
一个很实用的Socket通讯测试工具,支持TCP、UDP协议,可以作为客户端,也可以做为服务端,支持定时发送,支持发送文件。
1 安装时将本服务端解压到 D:\Muserver 2 安装SQL2000 + SP3 3 建立 MuOnline 和 Ranking 数据库 4 建立SQL数据库用户 Admin和MuAdmin指定到MuOnline数据库 BobStudio指定到Ranking数据库 5 还原 D:\Muserver\服务端...
描述中提到的“通过这种方式”,即使用`wsdl2java`,我们可以快速地访问Web服务端的接口,这是因为`wsdl2java`能自动处理WSDL文件中的所有细节,包括方法签名、数据类型映射等,生成对应的Java类和接口,使得开发者...
FTP服务端工具最小的FTP服务端工具(仅214K).最小的FTP服务端工具(仅214K).
使用java工具类可有效的提高开发效率!...[工具类] 通信服务端simpleServer.java [工具类] 框架StringUtil.java [工具类] 时间Time.java [工具类] 时间工具TimeUtil.java [工具类] 连数据库ConnectDB.java