Twilio 发送有关 android 个问题的文本

Twilio sending texts on android problems

我正在为需要发送短信的学校创建一个 android 应用程序。我有几个人推荐的 twilio,所以我决定使用它。按照本教程: https://www.twilio.com/blog/2016/05/how-to-send-an-sms-from-android.html ,使用我自己的 android 应用程序和一个包括我在调用 post 时收到 404 的应用程序(通过 ngrok 看到)。我完全不知所措,对 android 还是个新手。后端通过 intellij 给出以下信息: 8810 [qtp649044888-15] INFO spark.http.matching.MatcherFilter - 请求的路由 [/] 尚未在 Spark 中映射以接受:[null]

帐户 ID、地址、phone 号码等替换为 x's 后端:

//Heroku assigns different port each time, hence reading it from process.
        ProcessBuilder process = new ProcessBuilder();
        Integer port;
        if (process.environment().get("PORT") != null) {
            port = Integer.parseInt(process.environment().get("PORT"));
        } else {
            port = 4567;
        }
        Spark.port(port);


        get("/", (req, res) -> "Hello, World");

        TwilioRestClient client = new TwilioRestClient.Builder(System.getenv("ACxxxxxxx72279fb226f0dd162c869ce1e"), System.getenv("xxxxxxxc324a89155b93b5af26393297")).build();

        post("/sms", (req, res) -> {
            String body = req.queryParams("Body");
            String to = req.queryParams("To");
            String from = System.getenv("216450xxxx");

            Message message = new MessageCreator(
                    new PhoneNumber(to),
                    new PhoneNumber(from),
                    body).create(client);

            return message.getSid();
        });

App-post方法

Call post(String url, Callback callback) throws IOException {
        RequestBody formBody = new FormBody.Builder().add("To", "609420xxxx").add("Body", "TEST").build();
        Request request = new Request.Builder().url(url).post(formBody).build();
        Call response = mClient.newCall(request);
        response.enqueue(callback);
        Log.d("CALL: ", response.toString()+ "     " + callback.toString());
        return response;
    }

App post 按钮方法:

emailButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                try {
                    post("http://xxxxxxxx.ngrok.io", new  Callback(){
                        @Override
                        public void onFailure(Call call, IOException e) {
                            e.printStackTrace();
                        }

                        @Override
                        public void onResponse(Call call, Response response) throws IOException {
                            runOnUiThread(new Runnable() {
                                @Override
                                public void run() {
                                    Toast.makeText(getApplicationContext(),"SMS Sent!",Toast.LENGTH_SHORT).show();
                                }
                            });
                        }

                    });
                } catch (IOException e) {
                    e.printStackTrace();
                }

            }
        });

这应该是向我的号码发送短信(已在 twilio 帐户上验证),但我什么也没收到。吐司确实显示文本已发送。

查看 spark source code for MatcherFilter 对您遇到的错误的唯一引用是在未设置正文时引发的

if (body.notSet()) {
    LOG.info("The requested route [{}] has not been mapped in Spark for {}: [{}]",
             uri, ACCEPT_TYPE_REQUEST_MIME_HEADER, acceptType);

查看您链接到的 Twilio tutorial(假设您提供的代码正是您正在使用的代码),您似乎已经更改了代码以将变量硬编码到 类 和方法中。

我不太了解 Android 的编码,但我可以告诉你教程中的这一行引用了包含 Twilio 帐户 SID

的项目中的环境变量
(System.getenv("TWILIO_ACCOUNT_SID")

现在这是你的版本:

(System.getenv("ACxxxxxxx72279fb226f0dd162c869ce1e")

环境变量是设置一次的变量,通常在包含所有其他环境变量的文件中,并且特定于代码所在的用户或系统 运行。这些允许开发人员轻松更改用户或系统特定的变量值,即使他们在项目中多次引用了这些变量。

您正在尝试引用环境变量,但随后提供了您希望使用的值。不是这样的。

这是您的应用 post 按钮方法:

post("http://xxxxxxxx.ngrok.io", new  Callback(){

这是 Twilio 的:

post(mContext.getString("YOUR_NGROK_URL/sms"), new  Callback(){

您的硬编码 url 删除了对 mContext 变量的引用,我不知道这是否重要,但您忽略的另一件事是您需要添加 /sms到你的 URL.

结尾

鉴于您刚刚开始使用 Android,我的建议是暂时严格按照教程进行操作。偷工减料并在这里或那里进行一些更改似乎可以节省时间,但是当它不起作用时,您没有经验来理解问题所在。

无论如何,偷工减料、硬编码变量等都是一个坏习惯。我们都做过,后来我们都后悔了。正确学习,正确编码,添加注释解释你的代码,你将在未来避免无数小时的挫败感。