编写注册接口

1.编写注册接口

1.1 user/urls.py 中添加路由

urlpatterns = [ 
	path('register/', views.RegisterView.as_view()), # 注册视图, /user/register/ 
]

1.2 user/views.py 中写注册视图函数

class RegisterView(APIView):
    """ 用户注册, 权限是: 匿名用户可访问 """
    # 自定义权限类 
    permission_classes = (AllowAny,)
    
    def post(self,request):
        """ 
        接收邮箱和密码, 前端校验两遍一致性, 注册成功后返回成功, 然后用户自行登录获取token 
        1. 随机用户名 
        2. 生成用户 
        3. 设置用户密码 
        4. 保存用户 
        :param request: 
        :return: {'code':0,'msg':'注册成功'} 
        """
        email = request.data.get('email')
        passwrod = request.data.get('password')
        
        if all([email, passwrod]):
            pass
        else:
            return Response({'code':9999,'msg':'参数不全'})
        
        rand_name = self.randomUsername()
        
        user = User(username=rand_name, email=email) 
        user.set_password(passwrod) 
        user.save()
        
        return Response({'code': 0, 'msg': '注册成功'})
    
    def randomUsername(self):
        """ 
        生成随机用户名: 格式: SYL + 年月日时分 + 5位随机数 
        :return: 
        """
        d = datetime.datetime.now()
        base = 'SYL'
        time_str = '%04d%02d%02d%02d%02d' % (d.year, d.month, d.day, d.hour, 			d.minute)
        rand_num = str(random.randint(10000, 99999))
        
        return base + time_str + rand_num

2.重写django认证

2.1 syl/settings.py 中指定自定义后端认证函数位置

# 自定义验证后端
AUTHENTICATION_BACKENDS = ['user.utils.EmailAuthBackend']

2.2 user/utils.py 中重写认证函数

# 以前使用username进行用户验证,现在修改成email进行验证
class EmailAuthBackend:
    def authenticate(self, request, username=None, password=None):
        try:
            user = User.objects.get(username=username)
        except Exception as e:
            user = None
        if not user:
            try:
                user = User.objects.get(email=username)
            except Exception as e:
                user = None
        if user and user.check_password(password):
            return user
        else:
            return None
        
    def get_user(self, user_id):
        try:
            return User.objects.get(pk=user_id)
        except User.DoesNotExist:
            return None
        
            

3.注册用户 & 测试登录

3.1 注册接口测试

http://192.168.56.100:8888/user/register/

在这里插入图片描述

3.2 登录接口测试

注: 认证时只能识别username,所以必须要在请求中携带username字段

http://192.168.56.100:8888/user/login/

在这里插入图片描述
在这里插入图片描述

3.3 获取用户列表接口测试

  • 访问接口
http://192.168.56.100:8888/user/user/5/
  • 测试自定义权限

    # 自定义权限类 
    permission_classes = (MyPermission,) 
    # 自定义认证类, 自定义会覆盖全局配置 
    authentication_classes = (JSONWebTokenAuthentication,)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
编写 API 接口的方式和语言并没有直接关系,但是常见的方式是使用 C++ 编写后端服务,并在其中实现 API 接口。以下是一个简单的 C++ API 接口的示例: ```cpp #include <iostream> #include <string> #include <vector> #include <sstream> #include <memory> #include <map> class Api { public: virtual std::string execute(const std::vector<std::string>& args) = 0; }; class EchoApi : public Api { public: std::string execute(const std::vector<std::string>& args) override { std::stringstream ss; for (const auto& arg : args) { ss << arg << " "; } return ss.str(); } }; class ApiManager { public: void registerApi(const std::string& name, std::shared_ptr<Api> api) { api_map_[name] = api; } std::string execute(const std::string& name, const std::vector<std::string>& args) { if (api_map_.count(name) == 0) { return "Api not found: " + name; } auto api = api_map_[name]; return api->execute(args); } private: std::map<std::string, std::shared_ptr<Api>> api_map_; }; int main() { ApiManager api_manager; auto echo_api = std::make_shared<EchoApi>(); api_manager.registerApi("echo", echo_api); std::vector<std::string> args{"Hello,", "world!"}; std::cout << api_manager.execute("echo", args) << std::endl; return 0; } ``` 这个示例中,我们定义了一个 `Api` 接口和一个具体的实现 `EchoApi`,并将它们放入一个 `ApiManager` 中进行管理。在 `main()` 函数中,我们先将 `EchoApi` 注册到 `ApiManager` 中,并调用 `execute()` 函数传入参数执行接口。通过这个示例,我们可以看到 C++ 的面向对象编程风格和内存管理方式,以及如何使用容器和智能指针等 C++ 特性来实现 API 接口

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值