2

我正在为需要发送短信的学校创建一个 android 应用程序。我已经有几个人推荐了 twilio,所以我决定接受它。遵循本教程:https://www.twilio.com/blog/2016/05/how-to-send-an-sms-from-android.html,使用我自己的 android 应用程序和包括我在内的应用程序得到 404当 post 被调用时(通过 ngrok 看到)。我完全不知所措,对android还是很陌生。后端通过 intellij 给出以下消息: 8810 [qtp649044888-15] INFO spark.http.matching.MatcherFilter - The requested route [/] has not been mapped in Spark for Accept: [null]

账户ID、地址、电话号码等替换为x的Backend:

//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();
        });

应用程序发布方法

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;
    }

按钮上的应用发布方法:

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 帐户上验证),但我什么也没得到。吐司确实显示文本已发送。

4

1 回答 1

1

查看 MatcherFilter的 spark源代码,当未设置正文时,将引发对您所获得错误的唯一引用

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

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

我对 Android 编码了解不多,但我可以告诉你,教程中的这一行引用了项目中包含 Twilio 帐户 SID 的环境变量

(System.getenv("TWILIO_ACCOUNT_SID")

现在这是你的版本:

(System.getenv("ACxxxxxxx72279fb226f0dd162c869ce1e")

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

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

这是您在按钮方法上的应用帖子:

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

这是 Twilio 的:

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

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

我的建议是,因为您刚刚开始使用 Android,所以现在就按照教程进行操作。看起来您正在节省时间走捷径并在这里和那里更改一些位,但是当它不起作用时,您没有经验来理解哪里出了问题。

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

于 2017-12-04T21:41:34.510 回答