引起原因:libcore.io.ErrnoException:recvfrom失败:ECONNRESET由对等方重置连接和sendto失败:EPIPE断开的管道

如何解决引起原因:libcore.io.ErrnoException:recvfrom失败:ECONNRESET由对等方重置连接和sendto失败:EPIPE断开的管道

请不要将其标记为重复

你好 我正在创建一个Android应用,以从Google日历获取事件。我的设备没有Google Play服务,这是设备Philips 10bdl3051t / 02和Android版本4.4.4。 我已经通过App Auth从浏览器授权了用户,我已经获得了授权令牌并能够获取事件。该令牌在大约一小时内保持有效,然后需要刷新。 我正在使用以下代码刷新令牌。问题在于,有时它没有刷新的令牌并抛出此异常。

原因:libcore.io.ErrnoException:recvfrom失败:ECONNRESET(对等方重置连接)

原因:libcore.io.ErrnoException:sendto失败:EPIPE(管道损坏)

代码段以刷新令牌

private void checkGoogleCalendarRESTApiAuthToken() {
    SharedPreferences settings = getSharedPreferences(PREFS_FILE,0);
    SharedPreferences.Editor editor = settings.edit();

    // only refresh the token when it is about to expire
    long timeDifference = settings.getLong("googleCalendarRESTApiAccessTokenExpiry",new Date().getTime()) - new Date().getTime();
    Log.d("authtoken"," googleCalendarRESTApiAccessTokenExpiry : " + String.valueOf(settings.getLong("googleCalendarRESTApiAccessTokenExpiry",new Date().getTime())));
    Log.d("authtoken"," timeDifference: " + String.valueOf(timeDifference));
    if (timeDifference < 20) {
        Thread tokenRefreshTask = new Thread(){
        @Override
        public void run() {

            Log.d("authtoken"," tokenRefreshTask: " );
            mAuthState.performActionWithFreshTokens(new AuthorizationService(context),new AuthState.AuthStateAction() {
                @Override
                public void execute(@Nullable String accessToken,@Nullable String idToken,@Nullable AuthorizationException exception) {

                    Log.d("authtoken"," performActionWithFreshTokens: " );
                    editor.putString("googleCalendarRESTApiAccessToken",mAuthState.getAccessToken());
                    editor.putLong("googleCalendarRESTApiAccessTokenExpiry",mAuthState.getAccessTokenExpirationTime());
                    editor.apply();

                    HttpTransport transport = AndroidHttp.newCompatibleTransport();
                    JsonFactory jsonFactory = JacksonFactory.getDefaultInstance();
                    GoogleCredential googleAccountCredential = new GoogleCredential().setAccessToken(mAuthState.getAccessToken());
                    GoogleService = new com.google.api.services.calendar.Calendar.Builder(transport,jsonFactory,googleAccountCredential).build();


                    Log.d("authtoken"," getNeedsTokenRefresh: " + String.valueOf(mAuthState.getNeedsTokenRefresh()));
                    Log.d("authtoken"," getAccessTokenExpirationTime: " + String.valueOf(mAuthState.getAccessTokenExpirationTime()));
                    Log.d("authtoken"," getAccessToken: " + String.valueOf(mAuthState.getAccessToken()));
                    Log.d("authtoken"," isAuthorized: " + String.valueOf(mAuthState.isAuthorized()));
                    Log.d("authtoken"," getLastTokenResponse: " + String.valueOf(mAuthState.getLastTokenResponse()));
                    Log.d("authtoken"," getRefreshToken: " + String.valueOf(mAuthState.getRefreshToken()));
                    Log.d("authtoken"," getLastAuthorizationResponse: " + String.valueOf(mAuthState.getLastAuthorizationResponse()));
                }
            });
        }

    };tokenRefreshTask.start();
    }
}

此设备具有通过此代码控制的侧面LED,此代码每20秒运行一次,以使LED状态与日历事件保持同步。可能是这段代码造成了问题,如果发现任何问题,请提出修改建议。

// ledStripsColor = "#00FF00" for green
// ledStripsColor = "#FF0000" for red
// ledStripsMode = true
private void philipsLed(String ledStripsColor,boolean ledStripsMode) {

    Thread testing = new Thread() {
        @Override
        public void run() {
            Socket socket = null;
            OutputStream writer = null;
            int stripsColor = Color.parseColor(ledStripsColor);
            int mode = 0;
            if (ledStripsMode) {
                mode = 1; // 1 > turn on & 0 > turn off
            } else {
                mode = 0;
            }
            // Message //
            int messageSize = 9;
            int monitorId = 1;
            int groupId = 0;
            int command = 243; // To control the LED Strip
            int colorR = Color.red(stripsColor);
            int colorG = Color.green(stripsColor);
            int colorB = Color.blue(stripsColor);
            int checkSum = 0;

            List<Integer> list = new ArrayList<Integer>();
            list.clear();
            list.add(messageSize);
            list.add(monitorId);
            list.add(groupId);
            list.add(command);
            list.add(mode);
            list.add(colorR);
            list.add(colorG);
            list.add(colorB);

            for (int a = 0; a < 8; a++) {
                checkSum = checkSum ^ list.get(a);
            }

            try {
                // The server and the client is the same device so I used the loopback ip address.
                String ipAddress = "127.0.0.1";
                int portNo = 5000;
                socket = new Socket(ipAddress,portNo);
                socket.setKeepAlive( false );
                writer = socket.getOutputStream();

                writer.write((byte) messageSize);
                writer.write((byte) monitorId);
                writer.write((byte) groupId);
                writer.write((byte) command);
                writer.write((byte) mode);
                writer.write((byte) colorR);
                writer.write((byte) colorG);
                writer.write((byte) colorB);
                writer.write((byte) checkSum);
                writer.flush();
                writer.close();
                socket.close();
                
                // I have to run it multiple times as somehow it didn't change the colors of the LEDs at first time.
                // No.2 //
                socket = new Socket(ipAddress,portNo);
                socket.setKeepAlive( false );
                writer = socket.getOutputStream();

                sleep(100);

                writer.write((byte) messageSize);
                writer.write((byte) monitorId);
                writer.write((byte) groupId);
                writer.write((byte) command);
                writer.write((byte) mode);
                writer.write((byte) colorR);
                writer.write((byte) colorG);
                writer.write((byte) colorB);
                writer.write((byte) checkSum);
                writer.flush();
                writer.close();
                socket.close();

                // I have to run it multiple times as somehow it didn't change the colors of the LEDs at first time.
                // No.3 //
                socket = new Socket(ipAddress,portNo);
                socket.setKeepAlive( false );
                writer = socket.getOutputStream();

                sleep(100);

                writer.write((byte) messageSize);
                writer.write((byte) monitorId);
                writer.write((byte) groupId);
                writer.write((byte) command);
                writer.write((byte) mode);
                writer.write((byte) colorR);
                writer.write((byte) colorG);
                writer.write((byte) colorB);
                writer.write((byte) checkSum);

                writer.flush();
                writer.close();
                socket.close();

                Log.d("tag : ","color send");
            } catch (final Exception e) {
                // TODO Auto-generated catch block
                Log.d("tag : ","exception : " + e.getMessage());
                if (Toggle.toggle_Debug) {
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            Toast.makeText(getApplicationContext(),"exception : " + e.getMessage(),Toast.LENGTH_SHORT).show();
                        }

                    });
                }
                e.printStackTrace();
            }
        }
    };
    testing.start();

}

谢谢

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-