質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

4365閲覧

AndroidでOkHttpを使って自前サーバに画像をPOSTする方法

退会済みユーザー

退会済みユーザー

総合スコア0

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2016/07/15 05:07

編集2016/07/15 09:22

タイトルの通り, 自前のサーバ(node.js)にAndroidの端末からPOSTする方法についてです. Android5.0.2の実機でデバッグしています.
以下にコードを載せますが,errorはMainActivity.javaの中で ERROR!!とコメントアウトしてる部分に java.io.FileNotFoundException: /storage/emulated/0/(ファイル名).jpg: open failed: EACCES (Permission denied) と出ます.

file = new File(mImagePath) の手前のImageViewには画像がセットされるので, 画像までのPathは間違っていないと思います.

よろしくお願いします.

MainActivity.java

java

1protected void onActivityResult(int requestCode, int resultCode, Intent data){ 2 if(data == null){return;} 3 switch(requestCode){ 4 case UPLOAD_PIC_CODE: 5 mImagePath = getPath(data.getData());// get image path 6 mImageView.setImageURI(data.getData());// show the image 7 file = new File(mImagePath); 8 9 new AsyncTask<Void, Void, String>(){ 10 @Override 11 protected String doInBackground(Void... ImagePath) { 12 String result = null; 13 14 RequestBody requestBody = new MultipartBody.Builder() 15 .setType(MultipartBody.FORM) 16 .addFormDataPart("upName", file.getName(), RequestBody.create(MediaType.parse("image/*"), file)) 17 .build(); 18 19 Request request = new Request.Builder()// ERROR!! 20 .url(POST_URL) 21 .post(requestBody) 22 .build(); 23 24 try{ 25 okhttp3.Response response = client.newCall(request).execute(); 26 result = response.body().string(); 27 } catch (IOException e) { 28 e.printStackTrace(); 29 } 30 31 return result; 32 } 33 }.execute(); 34 break; 35 }// ERROR!! 36 } 37 38 39 public String getPath(Uri uri){ 40 String[] projection = {MediaStore.Images.Media.DATA}; 41 CursorLoader loader = new CursorLoader(getApplicationContext(), uri, projection, null, null, null); 42 Cursor cursor = loader.loadInBackground(); 43 int column_index = cursor.getColumnIndex(MediaStore.Images.Media.DATA); 44 cursor.moveToFirst(); 45 return cursor.getString(column_index); 46 } 47 48 @Override 49 public void onClick(View view) { 50 switch (view.getId()) { 51 case R.id.upload_button: 52 Intent intent = new Intent(Intent.ACTION_GET_CONTENT); 53 intent.setType("image/*"); 54 startActivityForResult(intent, UPLOAD_PIC_CODE); 55 break; 56 } 57 }

javascript

1(function() { 2 var express = require('express'); 3 var app = express(); 4 var mime = require('mime'); 5 var crypto = require('crypto'); 6 var multer = require('multer'); 7 8 // option 9 var storage = multer.diskStorage({ 10 destination: function(req, file, cb) { 11 cb(null, './uploads'); // absolute path 12 }, 13 filename: function(req, file, cb) { 14 var revName = file.originalname; // get original name 15 var imageType = file.mimetype; // get image type 16 var imageName = revName.split('.');// split . 17 console.log('split after is ' + imageName[0]); 18 console.log('split after is ' + imageName[1]); 19 crypto.pseudoRandomBytes(16, function(err, raw) { 20 // cb(null, raw.toString('hex') + imageName[0] + '.' + mime.extension(file.mimetype)); 21 cb(null, imageName[0] + '.' + mime.extension(file.mimetype)); 22 }); 23 } 24 }); 25 26 // set disk storage 27 var upload = multer({ 28 storage: storage 29 }); 30 31 app.post('/upload', upload.single('upName'), function(req, res) { 32 // call option 33 console.log('-----post function------'); 34 console.log(`originalname: ${req.file.originalname}`); 35 console.log(`path: ${req.file.path}`); 36 //res.send(JSON.stringify(req.file)); 37 res.json({'response': 'Get!'}); 38 //console.log('-----req-----'); 39 console.log(req.file); 40 }); 41 42 app.get('/', function(req,res){ 43 res.end('node file upload'); 44 }); 45 46 47 app.use('/', express.static('.')); 48 app.listen(3000); 49 console.log('http://localhost:3000 is generated.'); 50})();

AndroidManifest.xml

xml

1<uses-permission android:name="android.permission.INTERNET"/> 2 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 3 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> 4 5 <application 6 android:allowBackup="true" 7 android:icon="@mipmap/ic_launcher" 8 android:label="@string/app_name" 9 android:supportsRtl="true" 10 android:theme="@style/AppTheme"> 11 <activity android:name=".MainActivity"> 12 <intent-filter> 13 <action android:name="android.intent.action.MAIN" /> 14 15 <category android:name="android.intent.category.LAUNCHER" /> 16 </intent-filter> 17 </activity> 18 </application>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

dsuzuki

2016/07/15 05:53

パーミッション設定を確認するため、AndroidManifest.xmlの追記をお願いします。
退会済みユーザー

退会済みユーザー

2016/07/15 06:56

追加しました.ご指摘ありがとうございます
amay077

2016/07/15 07:48

例えば 「 file = new File(mImagePath);」以降の処理を行わない(コメントアウトする)と、画面(mImageView)に目的の画像が表示されるのでしょうか? このように「○○までは期待通り動いている」という情報があると、回答が得られやすいと思います。
退会済みユーザー

退会済みユーザー

2016/07/15 09:18

なるほど.ありがとうございます.修正します
guest

回答2

0

ベストアンサー

mImageView.setImageURI(data.getData()) は成功していることから、 ストレージへのアクセス権限(READ_EXTERNAL_STORAGE)は正しく機能していると考えられます。

一方で、 FileNotFoundException... Permission denied が発生するということは、getPath(data.getData()) で得られるファイルパスに何らかの原因があると思います。

data.getData()URI を返しますが、URI は常に「ファイルパス」を含むとは限りません。

画像の取得に ACTION_GET_CONTENT によるコンテントプロバイダを使用していますが、この場合も同じく「ファイルパス」を返さない場合があります。

によると、

content://com.android.providers.media.documents/documents/image:234

のようなデータを返す場合がある模様です。

data.getData()getPath(…) の実際のデータを文字列で出力して確認してみてください。
あるいは、 file = new File(mImagePath); の後で、 file.exists()true を返しているか確認してみてください。

「ファイルパス」でない場合は、

の方法で、「ファイルパス」が取得できるようですので、合わせて確認してみてください。

mImageView.setImageURI(data.getData()) が正常に動作するのは、このメソッドが、「ファイルパス」以外の URI も正しく処理する機能を持っているからと思います。

投稿2016/07/15 09:54

amay077

総合スコア1075

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

Androidアプリの実行環境は、エミュレータでしょうか。
エミュレータの「設定」-「アプリ」で該当のアプリの「許可」項目を確認して下さい。
ストレージの項目がOffになっていないでしょうか。
パーミッションの設定で項目が追加され、エミュレータの設定から許可をOnにすることで利用できるようになります。

投稿2016/07/15 08:50

dsuzuki

総合スコア1682

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2016/07/15 09:22

実行環境は実機のAndroid 5.0.2ですね.その項目があるか確認してみます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問