Django REST_framework APIView
Alternatives To Django_restframework_apiview
Project NameStarsDownloadsRepos Using ThisPackages Using ThisMost Recent CommitTotal ReleasesLatest ReleaseOpen IssuesLicenseLanguage
Python 100 Days135,076
a month ago682Python
Python - 100天从新手到大师
Django Rest Framework25,66624,5951,508a day ago134December 15, 2021132otherPython
Web APIs for Django. 🎸
Awesome Django7,045
6 days ago2cc0-1.0HTML
A curated list of awesome things related to Django
Drf Yasg3,0922907619 days ago59October 25, 2020235otherPython
Automated generation of real Swagger/OpenAPI 2.0 schemas from Django REST Framework code.
Django Rest Swagger2,5162,031413 years ago50April 30, 2018168bsd-2-clausePython
Swagger Documentation Generator for Django REST Framework: deprecated
Django Rest Auth2,3311,1092410 months ago25April 01, 2019234mitPython
This app makes it extremely easy to build Django powered SPA's (Single Page App) or Mobile apps exposing all registration and authentication related functionality as CBV's (Class Base View) and REST (JSON)
Djoser2,288212511 days ago48October 30, 2020166mitPython
REST implementation of Django authentication system.
Drf Nested Routers1,4876212913 days ago19October 15, 202146apache-2.0Python
Nested Routers for Django Rest Framework
Cookiecutter Django Rest1,405
4 days ago4mitPython
Build best practiced apis fast with Python3
Drf Extensions1,371323149 days ago16July 30, 202175mitPython
DRF-extensions is a collection of custom extensions for Django REST Framework
Alternatives To Django_restframework_apiview
Select To Compare

Alternative Project Comparisons

Django REST_framework APIView


Use in your app

Install using pip:

pip install django_restframework_apiview

Add 'apiview' to your INSTALLED_APPS setting:


JSONP Renderer And debug apiview with paramslist:


Add error code to

    ('ERR_AUTH_NOLOGIN',            10001,  'No login'),
    ('ERR_AUTH_USER_EXISTS',        10002,  'User name has exists'),
    ('ERR_AUTH_USER_NOT_EXISTS',    10003,  'User not exists'),
    ('ERR_AUTH_PASSWORD',           10005,  'Password error'),

edit myapp/

#! usr/bin/env python
# encoding: utf-8
from __future__ import absolute_import, unicode_literals

from django.db import IntegrityError, transaction
from django.contrib.auth import authenticate, login
from django.contrib.auth.models import User
from apiview.err_code import ErrCode
from apiview.exceptions import CustomError
from apiview.view import APIView
from apiview.views import ViewSite
from apiview.views import fields

site = ViewSite(name='base', app_name='base')

class APIBase(APIView):

    class Meta:
        path = '/'
        param_fields = (
            ('channel', fields.CharField(help_text='App Channel', required=False)),
            ('version', fields.CharField(help_text='App Version', required=False)),

class UserAPIBase(APIBase):

    def check_user_permission(self, request):
        user = request.user
        if not user.is_authenticated() or not isinstance(user, User):
            raise CustomError(ErrCode.ERR_AUTH_NOLOGIN)

    def view(self, request, *args, **kwargs):
        return super(APIBase, self).view(request, *args, **kwargs)

    class Meta:
        path = '/user'

class Login(APIBase):

    name = ''

    def get_context(self, request, *args, **kwargs):
        user = authenticate(username=request.params.username, password=request.params.password)
        if user is None:
            raise CustomError(ErrCode.ERR_AUTH_PASSWORD)
        login(request, user)
        return self.get_default_context(user_info={'username':request.user.username, 'email'})

    class Meta:
        path = 'user/login'
        param_fields = (
            ('username', fields.CharField(help_text='')),
            ('password', fields.CharField(help_text='')),

class Register(APIBase):

    name = ''

    def get_context(self, request, *args, **kwargs):
            user = User.objects.create_user(request.params.username,, request.params.password)
        except IntegrityError:
            raise CustomError(ErrCode.ERR_AUTH_USER_EXISTS)
        return self.get_default_context()

    class Meta:
        path = 'user/register'
        param_fields = (
            ('username', fields.RegexField(help_text='', regex=r'^[a-zA-Z0-9_]{3,10}$')),
            ('password', fields.CharField(help_text='')),
            ('email', fields.EmailField(help_text='Email')),

class Info(UserAPIBase):

    name = ''

    def get_context(self, request, *args, **kwargs):
        user_info = {'username':request.user.username, 'email'}

        return self.get_default_context(user_info=user_info)

class Logout(UserAPIBase):

    name = ''

    def get_context(self, request, *args, **kwargs):

        return self.get_default_context()

urlpatterns = site.urlpatterns

add to end:

urlpatterns.append(url(r'^test/', include("myapp.views")))


run example:

git clone
cd django_restframework_apiview/example
pip install -r requirements.txt
python makemigrations
python migrate
python runserver
open in browser
api demo::
Popular Django Projects
Popular Rest Projects
Popular Frameworks Categories

Get A Weekly Email With Trending Projects For These Categories
No Spam. Unsubscribe easily at any time.