android发送定位信息到mysql_Android实现实时定位并发送信息至服务器之动态权限(三)...

本文介绍了在Android 6.0及以上版本中如何进行动态权限申请,特别是针对Dangerous Permissions。通过示例展示了如何在没有电话权限时进行申请,并使用EasyPermissions库简化权限管理。同时,文章讨论了将定位信息发送到MySQL服务器的主题。
摘要由CSDN通过智能技术生成

这篇讲下权限的动态申请,在 Android6.0 以后权限机制分为两类,Normal Permissions,这类权限是不需要用户授权,不会触及用户的隐私,只需要在 manefest 里面申请即可;还有一类是 Dangerous Permissions,即动态申请。

实现的方式也有很多,普通的或者更多的封装第三方库。

权限申请的流程

1.在 AndroidManifest 里面配置需要的权限,无论是普通的还是特殊的权限都需要在这里配置。

2.检查权限,如果没有权限则申请

3.给用户申请权限的解释,这个方法只会在第一次用户拒绝授权,再次去申请这个的权限时会用到

4.申请相应的权限

5.处理申请权限的回调,在这里获得哪些授权成功哪些失败,处理需要的逻辑

普通的方式[申请电话权限]

public class Main2Activity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main2);

if (ContextCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE)

!= PackageManager.PERMISSION_GRANTED) {//未获取权限

if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.CALL_PHONE)) {

//当用户第一次申请拒绝时,再次申请该权限调用

Toast.makeText(this, "拨打电话权限", Toast.LENGTH_SHORT).show();

}

//申请权限

ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CALL_PHONE}, 0x01);

} else {//已经获得了权限

call();

}

}

private void call() {

Toast.makeText(this, "打电话", Toast.LENGTH_SHORT).show();

}

@Override

public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults);

if (requestCode == 0x01) {

if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {//授权成功

call();

} else {//授权失败

Toast.makeText(this, "获取权限失败", Toast.LENGTH_SHORT).show();

}

}

}

}

封装的第三方库,这里我用的是 EasyPermissions,调用也非常的方便

compile 'pub.devrel:easypermissions:0.1.5'

在 Activite 中调用

public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {

private static final String TAG = "lzy";

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//所要申请的权限

String[] perms = {Manifest.permission.WRITE_EXTERNAL_STORAGE, Manifest.permission.CALL_PHONE};

if (EasyPermissions.hasPermissions(this, perms)) {//检查是否获取该权限

Log.i(TAG, "已获取权限");

} else {

//第二个参数是被拒绝后再次申请该权限的解释

//第三个参数是请求码

//第四个参数是要申请的权限

EasyPermissions.requestPermissions(this, "必要的权限", 0, perms);

}

}

@Override

public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults);

//把申请权限的回调交由EasyPermissions处理

EasyPermissions.onRequestPermissionsResult(requestCode, permissions, grantResults, this);

}

//下面两个方法是实现EasyPermissions的EasyPermissions.PermissionCallbacks接口

//分别返回授权成功和失败的权限

@Override

public void onPermissionsGranted(int requestCode, List perms) {

Log.i(TAG, "获取成功的权限" + perms);

}

@Override

public void onPermissionsDenied(int requestCode, List perms) {

Log.i(TAG, "获取失败的权限" + perms);

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现实时聊天应用程序,您需要使用以下技术: 1. Spring Boot:用于构建应用程序后端,它提供了一组开箱即用的库和工具,使构建Web应用程序变得容易。 2. MySQL:用于存储应用程序的数据,例如用户信息,聊天记录等。 3. Android Studio:用于构建移动应用程序的开发环境。 4. Socket.IO:用于实现实时通信的JavaScript库。 下面是实现步骤: 1. 首先,您需要创建一个Spring Boot应用程序,并将MySQL作为数据库。您可以使用Spring Initializr来创建应用程序。 2. 创建一个名为“chat”的数据库,并添加“users”和“messages”表。用户表将存储用户信息,例如用户名和密码。消息表将存储聊天记录。 3. 创建一个REST API,用于处理用户注册,登录和消息发送请求。您可以使用Spring MVC来创建API。 4. 在Android Studio中创建一个新的Android应用程序,并添加Socket.IO库。这将允许您通过WebSocket通信协议实现实时通信。 5. 实现用户注册和登录功能。当用户注册时,将其用户名和密码保存到MySQL数据库中。当用户登录时,验证其凭据并返回一个JSON Web Token(JWT)。 6. 实现消息发送和接收功能。在Android应用程序中,您可以使用Socket.IO库将消息发送到后端,然后将其保存到MySQL数据库中。在后端,您可以使用Socket.IO库将消息推送给其他连接到应用程序的客户端。 7. 实现聊天界面。在Android应用程序中,您可以使用RecyclerView和Adapter来显示聊天记录。当新消息到达时,将其添加到RecyclerView中。 8. 最后,测试您的应用程序。确保您可以注册,登录,发送消息并收到实时通知。 希望这可以帮助您实现实时聊天应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值