- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在我的 Ionic3.4 应用程序中集成了 Instagram 身份验证。成功登录后,我从身份验证响应中存储用户的 token 和 UID。接下来,我对 Instagram 端点进行 api 调用以获取当前用户的照片。它在 Android 上完美运行。但它不适用于iOS平台。它抛出以下错误:
这是我用来从 Instagram 获取照片的代码:
InstagramService.ts:
@Injectable()
export class InstagramService {
constructor(public http: Http) {
}
getInstagramUserInfo(accessToken) {
//GET USER PHOTOS
return this.http
.get('https://api.instagram.com/v1/users/self/media/recent?access_token=' + accessToken)
.map((res: Response) => res.json())
.map((res: any) => {
let images: Array<String> = [];
res.data.forEach(element => {
images.push(element.images.thumbnail.url);
});
return images;
})
.catch((error: any) =>
Observable.throw(error.json().error || 'Server error')
);
}
}
instagram-photos.ts:
getInstagramPhotos(accessToken) {
this.showLoading();
this.instagramService.getInstagramUserInfo(accessToken)
.subscribe((response: Array<string>) => {
this.images = response;
this.hideLoading();
}, (error: any) => {
alert(JSON.stringify(error));
this.hideLoading();
});
}
instagram-photos.html:
<ion-content padding="true">
<ion-grid>
<div *ngFor="let image of images; let i = index;">
<ion-row *ngIf="i % 3 === 0">
<ion-col col-4 (click)="openPhoto(image)" *ngIf="i < images.length">
<img [src]="images[i]" />
</ion-col>
<ion-col col-4 (click)="openPhoto(image)" *ngIf="i+1 < images.length">
<img [src]="images[i+1]" />
</ion-col>
<ion-col col-4 (click)="openPhoto(image)" *ngIf="i+2 < images.length">
<img [src]="images[i+2]" />
</ion-col>
</ion-row>
</div>
</ion-grid>
</ion-content>
现在,main.js 在第 60951 行附近看起来像下面这样:
附言:
如果您想了解 ionic 信息
$ ionic 信息
全局包:
@ionic/cli-utils : 1.4.0
Cordova CLI : 7.0.1
Ionic CLI : 3.4.0
本地包:
@ionic/app-scripts : 1.3.7
@ionic/cli-plugin-cordova : 1.4.0
@ionic/cli-plugin-ionic-angular : 1.3.1
Cordova Platforms : ios 4.4.0
Ionic Framework : ionic-angular 3.3.0
系统:
Node : v6.11.0
OS : macOS Sierra
Xcode : Xcode 8.2.1 Build version 8C1002
ios-deploy : 1.9.1
ios-sim : not installed
npm : 3.10.10
编辑:1
我继续在 Safari 上调试应用程序,我在调用 api 时发现了这个问题:
XMLHttpRequest cannot load https://api.instagram.com/v1/users/self/media/recent?access_token=XXXXXXXXXXXXXXXXX. Origin null is not allowed by Access-Control-Allow-Origin.
谁能提出解决方案?
最佳答案
好的。我找到了解决方案。 Instagram API 支持 JSONP,所以当设备是 iOS 时,我进行了 jsonp 调用而不是 http 调用。我实现如下:首先,在 app.module.ts 中,将 JsonpModule 导入为:
import { JsonpModule } from '@angular/http';
然后,将 JsonpModule 添加到 imports 数组中:
@NgModule({
declarations: [...],
imports: [
...,
JsonpModule
],
bootstrap: [IonicApp],
entryComponents: [...],
providers: [...]
})
最后,我检查了如果平台是 android
则进行正常的 Http
调用,如果平台是 ios
则进行 Jsonp
调用。就是这样...!!
import { Injectable } from '@angular/core';
import { Http, Response, Jsonp } from '@angular/http';
import 'rxjs/add/operator/map';
import { Observable } from "rxjs/Observable";
import { Platform } from "ionic-angular";
@Injectable()
export class InstagramService {
constructor(private http: Http, private jsonp: Jsonp, private platform: Platform) {
}
getInstagramUserInfo(accessToken) {
if (this.platform.is('android')) {
return this.http
.get('https://api.instagram.com/v1/users/self/media/recent?access_token=' + accessToken, {})
.map((res: Response) => res.json())
.map((res: any) => {
let images: Array<String> = [];
res.data.forEach(element => {
images.push(element.images.thumbnail.url);
});
return images;
})
.catch((error: any) =>
Observable.throw(error.json().error || 'Server error')
);
} else {
return this.jsonp
.get('https://api.instagram.com/v1/users/self/media/recent?access_token=' + accessToken + "&callback=JSONP_CALLBACK", {})
.map((res: Response) => res.json())
.map((res: any) => {
let images: Array<String> = [];
res.data.forEach(element => {
images.push(element.images.thumbnail.url);
});
return images;
})
.catch((error: any) =>
Observable.throw(error.json().error || 'Server error')
);
}
}
}
关于android - iOS:Instagram Api 抛出错误消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44720311/
IO 设备如何知道属于它的内存中的值在memory mapped IO 中发生了变化? ? 例如,假设内存地址 0 专用于保存 VGA 设备的背景颜色。当我们更改 memory[0] 中的值时,VGA
我目前正在开发一个使用Facebook sdk登录(通过FBLoginView)的iOS应用。 一切正常,除了那些拥有较旧版本的facebook的人。 当他们按下“使用Facebook登录”按钮时,他
假设我有: this - is an - example - with some - dashesNSRange将使用`rangeOfString:@“-”拾取“-”的第一个实例,但是如果我只想要最后
Card.io SDK提供以下详细信息: 卡号,有效期,月份,年份,CVV和邮政编码。 如何从此SDK获取国家名称。 - (void)userDidProvideCreditCardInfo:(Car
iOS 应用程序如何从网络服务下载图片并在安装过程中将它们安装到用户的 iOS 设备上?可能吗? 最佳答案 您无法控制应用在用户设备上的安装,因此无法在安装过程中下载其他数据。 只需在安装后首次启动应
我曾经开发过一款企业版 iOS 产品,我们公司曾将其出售给大型企业,供他们的员工使用。 该应用程序通过 AppStore 提供,企业用户获得了公司特定的配置文件(包含应用程序配置文件)以启用他们有权使
我正在尝试将 Card.io SDK 集成到我的 iOS 应用程序中。我想为 CardIO ui 做一个简单的本地化,如更改取消按钮标题或“在此保留信用卡”提示文本。 我在 github 上找到了这个
我正在使用 CardIOView 和 CardIOViewDelegate 类,没有可以设置为 YES 的 BOOL 来扫描 collectCardholderName。我可以看到它在 CardIOP
我有一个集成了通话工具包的 voip 应用程序。每次我从我的 voip 应用程序调用时,都会在 native 电话应用程序中创建一个新的最近通话记录。我在 voip 应用程序中也有自定义联系人(电话应
iOS 应用程序如何知道应用程序打开时屏幕上是否已经有键盘?应用程序运行后,它可以接收键盘显示/隐藏通知。但是,如果应用程序在分屏模式下作为辅助应用程序打开,而主应用程序已经显示键盘,则辅助应用程序不
我在模拟器中收到以下错误: ImageIO: CGImageReadSessionGetCachedImageBlockData *** CGImageReadSessionGetCachedIm
如 Apple 文档所示,可以通过 EAAccessory Framework 与经过认证的配件(由 Apple 认证)进行通信。但是我有点困惑,因为一些帖子告诉我它也可以通过 CoreBluetoo
尽管现在的调试器已经很不错了,但有时找出应用程序中正在发生的事情的最好方法仍然是古老的 NSLog。当您连接到计算机时,这样做很容易; Xcode 会帮助弹出日志查看器面板,然后就可以了。当您不在办公
在我的 iOS 应用程序中,我定义了一些兴趣点。其中一些有一个 Kontakt.io 信标的名称,它绑定(bind)到一个特定的 PoI(我的意思是通常贴在信标标签上的名称)。现在我想在附近发现信标,
我正在为警报提示创建一个 trigger.io 插件。尝试从警报提示返回数据。这是我的代码: // Prompt + (void)show_prompt:(ForgeTask*)task{
您好,我是 Apple iOS 的新手。我阅读并搜索了很多关于推送通知的文章,但我没有发现任何关于 APNS 从 io4 到 ios 6 的新更新的信息。任何人都可以向我提供 APNS 如何在 ios
UITabBar 的高度似乎在 iOS 7 和 8/9/10/11 之间发生了变化。我发布这个问题是为了让其他人轻松找到答案。 那么:在 iPhone 和 iPad 上的 iOS 8/9/10/11
我想我可以针对不同的 iOS 版本使用不同的 Storyboard。 由于 UI 的差异,我将创建下一个 Storyboard: Main_iPhone.storyboard Main_iPad.st
我正在写一些东西,我将使用设备的 iTunes 库中的一部分音轨来覆盖 2 个视频的组合,例如: AVMutableComposition* mixComposition = [[AVMutableC
我创建了一个简单的 iOS 程序,可以顺利编译并在 iPad 模拟器上运行良好。当我告诉 XCode 4 使用我连接的 iPad 设备时,无法编译相同的程序。问题似乎是当我尝试使用附加的 iPad 时
我是一名优秀的程序员,十分优秀!