Manage封装一个网络请求

Manage封装一个网络请求

前言

在进行网络请求时,我们可以用单例模式,创建一个全局的Manage类,用实例Manage来执行网络请求方法,顺便用Manage传递请求数据,在model里完成数据解析。

一、单例模式

  1. 在iOS开发过程中,需要使用到一些全局变量以及管理方法,可以将这些变量以及方法封装在一个管理类中,这是符合MVC开发模式的,这就需要使用单例(singleton)。
  2. 使用单例模式的变量在整个程序中只需要创建一次,而它生命周期是在它被使用时创建一直到程序结束后进行释放的,类似于静态变量,所以我们需要考虑到它的生命周期,唯一性以及线程安全。

有两种方法来实现单例:
第一种:通过static全局变量来实现

#import "Manager.h"

static Manager *manager = nil;

@implementation Manager

 + (instancetype)sharedManage {
    if (!manager) {//判断static全局变量是否为nil,如果该全局变量为nil
        static dispatch_once_t onceToken;
        dispatch_once(&onceToken, ^{
            manager = [Manager new];//初始化一个实例并赋值给static全局变量
        });
    }
    return manager;
}
@end

这里介绍一下static的简单用法:
1.可以修饰局部变量,将局部变量存储到静态存储区。
2.可以修饰全局变量,限定全局变量只能在当前源文件中访问。
3.可以修饰函数,限定该函数只能在当前源文件调用。

  • 这里static的作用:类方法不可以访问实例变量,通过static修饰的实例变量 ,可以被类方法访问。
  • dispatch_ once _t: 使用 dispatch_once 方法能保证某段代码在程序运行过程中只被执行1次,并且即使在多线程的环境下,dispatch _once也可以保证线程安全。
  • 记得要在类接口部分声明类方法(允许程序通过该方法获得该类的唯一实例)

第二种:通过@synchronized
@synchronized 相当于一把锁,锁住了self,用来防止其他线程对代码块中进行操作,但相比于第一种性能较低,所以通常使用第一种。

二、demo

这里以上一篇博客JSONModel的嵌套为例

Manager封装一个网络请求就是把之前网络请求复杂的代码现在写在一个函数里边,调用该函数就实现了网络请求。

这里用到了block传值,是用来将该文件中网络请求获得到的数据传给另一个文件。

Manager.h文件中:

#import "JSONModel.h"
#import "TestModel.h"
NS_ASSUME_NONNULL_BEGIN
//自定义类型block
typedef void (^DataBlock) (TestModel* _Nonnull mainViewModel);
typedef void (^ErrorBlock) (NSError* _Nonnull error);

@interface Manager : JSONModel
+ (instancetype)sharedManage;
- (void)NetWorkWithData:(DataBlock) dataBlock error:(ErrorBlock) errorBlock;
@end

Manager.m文件中:

#import "Manager.h"
static Manager* manager;
@implementation Manager

+(instancetype)sharedManage {
    if(!manager) {
        static dispatch_once_t onceToken;
        dispatch_once(&onceToken, ^{
            manager = [Manager new];
        });
    }
    return manager;
}

在这个函数中完成网络请求的操作,并将请求到的值进行block传值。

- (void)NetWorkWithData:(DataBlock) dataBlock error:(ErrorBlock) errorBlock {
    NSString* urlString = [[NSString alloc] init];
    urlString = @"https://news-at.zhihu.com/api/4/news/latest";
    urlString = [urlString stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet URLQueryAllowedCharacterSet]];
    NSURL *url = [NSURL URLWithString:urlString];
    NSLog(@"%@", urlString);
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
    NSURLSession* session = [NSURLSession sharedSession];
    NSURLSessionDataTask* dataTask = [session dataTaskWithRequest:request completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
        if (error == nil) {
            TestModel* value = [[TestModel alloc] initWithData:data error:nil];
            dataBlock(value);//block调用
        } else {
            errorBlock(error);
        }
    }];
    [dataTask resume];
}

在ViewController的.m文件中:
接受block传来的值,并进行相应操作

- (void)test {
    [[Manager sharedManage] NetWorkWithData:^(TestModel * _Nonnull mainViewModel) {
        NSLog(@"%@",mainViewModel.top_stories[2]);
        NSLog(@"请求成功");
    } error:^(NSError * _Nonnull error) {
        NSLog(@"请求失败");
    }];
}

运行结果如下:
在这里插入图片描述

### 回答1: 你好!这是你可以使用 Django 创建用户注册功能的步骤: 1. 在 Django 项目中创建一个新的应用。 2. 在应用中创建一个模型来存储用户信息,例如用户名、密码和电子邮件地址。 3. 使用 Django 自带的表单功能来创建注册表单。 4. 在视图中编写代码来处理表单提交,并将用户信息存储到数据库中。 5. 使用 Django 的模板功能在网页上显示注册表单。 6. 在 URLconf 中创建一个 URL 来访问注册表单。 这些步骤只是大致的指导,你可能还需要配置 Django 认证系统、使用信号量来发送欢迎邮件、以及其他一些操作。如果你对 Django 的用户认证系统感到困惑,你可以考虑使用 Django Allauth 这个第三方库来简化开发流程。 ### 回答2: 使用Django编写一个注册功能可以分为以下几个步骤: 1. 创建Django项目和应用程序:首先,在命令行中使用Django命令创建一个新的项目,然后创建一个新的应用程序。可以使用`django-admin startproject project_name`命令创建一个新的项目,再使用`python manage.py startapp app_name`命令创建一个新的应用程序。 2. 定义模型:在应用程序的models.py文件中,创建一个User模型类来表示用户信息。可以定义用户名、密码、电子邮箱等字段,并根据需要添加其他字段。 3. 创建表单:在应用程序的forms.py文件中,创建一个注册表单类。这个表单类可以继承Django提供的UserCreationForm类,该类已经封装了用户注册所需的字段和验证方法。 4. 创建视图:在应用程序的views.py文件中,创建一个视图函数来处理用户注册的逻辑。该函数接收用户提交的注册表单数据,通过表单验证后,创建一个新的User实例并保存到数据库中。 5. 设置URL:在项目的urls.py文件中,配置一个URL路由映射,将用户注册的URL请求指向之前定义的视图函数。 6. 创建模板:在应用程序的templates文件夹中,创建一个register.html模板文件。该文件包含一个表单,用于用户输入注册信息,并提交给服务器处理。 7. 配置静态文件:在项目的settings.py文件中,配置静态文件路径,将CSS和JavaScript文件引入到register.html模板中,实现页面的美化和交互。 8. 运行项目:在命令行中使用`python manage.py runserver`命令启动Django开发服务器,然后在浏览器中访问注册页面,填写注册信息并提交,完成用户注册。 以上是使用Django编写一个注册功能的大致步骤,具体实现和细节可以根据实际需求进行调整和完善。 ### 回答3: 使用Django编写一个注册功能非常简单。首先,我们需要创建一个Django项目。在命令行中运行`django-admin startproject myproject`来创建一个名为`myproject`的项目。 接下来,在项目的根目录中,我们可以通过运行`python manage.py startapp registration`来创建一个名为`registration`的应用程序。 在`registration`应用程序的文件夹中,我们需要创建一个名为`views.py`的文件。在这个文件中,我们将编写注册功能的代码。以下是一个简单的示例: ```python from django.shortcuts import render, redirect from .forms import RegistrationForm def register(request): if request.method == 'POST': form = RegistrationForm(request.POST) if form.is_valid(): form.save() return redirect('registration_success') else: form = RegistrationForm() return render(request, 'registration/register.html', {'form': form}) def registration_success(request): return render(request, 'registration/success.html') ``` 在这个例子中,我们首先导入了`render`函数和`redirect`函数,以及一个名为`RegistrationForm`的表单类。`RegistrationForm`类是在应用程序的`forms.py`文件中定义的,用于定义注册表单的字段和验证规则。 在`register`函数中,我们首先检查请求的方法是否为POST。如果是,则实例化`RegistrationForm`类,并检查表单是否有效。如果表单有效,我们保存表单数据并重定向到`registration_success`视图函数。 如果请求的方法不是POST,我们实例化一个空的`RegistrationForm`对象,并将其传递给模板以呈现。 在`registration_success`函数中,我们只是渲染一个成功注册的页面。 最后,我们需要为我们的视图函数创建URL模式。在项目的根URL配置文件中,我们可以添加以下代码: ```python from django.urls import path from registration import views urlpatterns = [ path('register/', views.register, name='register'), path('registration_success/', views.registration_success, name='registration_success'), ] ``` 在这个URL配置中,我们将`register`函数映射到`/register/`路径,并将其命名为`register`。同样,我们将`registration_success`函数映射到`/registration_success/`路径,并将其命名为`registration_success`。 这样,我们就完成了使用Django编写注册功能的过程。当用户访问/register/路径时,他们将看到一个注册表单,填写并提交表单后,将被重定向到一个成功注册的页面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值