Xcode редактировать и добавлять данные в базе данных MySQL

Я вернулся к проекту, который я начал несколько лет назад в XCode. Это был мой первый проект XCode, и мне потребовалось немало времени на обучение, но в итоге я заставил приложение работать так, как ему хотелось. Сейчас я вернулся в проект, чтобы добавить некоторые функции, но у меня возникли проблемы с возвращением и пониманием того, как работает мой код. По сути, сейчас приложение связывается с базой данных mySQL и отображает данные из базы данных в любом месте, которое выберет пользователь. Теперь я хочу добавить функцию, где пользователь может редактировать эти данные / добавлять данные в базу данных. До сих пор я не смог найти никаких полезных руководств или решений. Вот мой код для хранения данных из базы данных.

//
//  City.h
//  webView
//
//  Created by 1234 on 14-04-07.
//  Copyright (c) 2014 1234. All rights reserved.
//

#import <Foundation/Foundation.h>

@interface City : NSObject
@property (nonatomic, strong)NSString * cityName;
@property (nonatomic, strong)NSString * clubName;
@property (nonatomic, strong)NSString * clubLine;
@property (nonatomic, strong)NSString * cityID;
@property (nonatomic, strong)NSString * cityCountry;
@property (nonatomic, strong)NSString * price;
@property (nonatomic, strong)NSString * camera;
@property (nonatomic, strong)NSString * taxi;
@property (nonatomic, strong)NSString * promo;
@property (nonatomic, strong)NSNumber * Latitude;
@property (nonatomic, strong)NSNumber * Longitude;

-(id)initWithCityName: (NSString *)cName andCityCountry: (NSString *)cCountry andClubName:   (NSString *)clName  andClubLine: (NSString *)cLine andPrice: (NSString *)pri andPromo: (NSString *)prom andCamera: (NSString *)cam andTaxi:(NSString *)taxi andLatitude: (NSNumber *)cLatitude andLongitude: (NSNumber *)cLongitude andCityId: (NSString *)cID ;@end

//

//
//  City.m
//  webView
//
//  Created by 1234 on 14-04-07.
//  Copyright (c) 2014 1234. All rights reserved.
//

#import "City.h"
@implementation City
@synthesize cityCountry, cityID, Latitude, Longitude, cityName, clubName, clubLine,taxi,     price,promo,camera;

-(id)initWithCityName: (NSString *)cName andCityCountry: (NSString *)cCountry andClubName:     (NSString *)clName  andClubLine: (NSString *)cLine andPrice: (NSString *)pri andPromo: (NSString *)prom andCamera: (NSString *)cam andTaxi:(NSString *)tax andLatitude: (NSNumber *)cLatitude andLongitude: (NSNumber *)cLongitude andCityId: (NSString *)cID ;
{
self=[super init];
if(self)
{
cityName=cName;
cityCountry=cCountry;
clubName= clName;
clubLine=cLine;
price=pri;
promo=prom;
camera=cam;
Latitude= cLatitude;
Longitude= cLongitude;
cityID=cID;
taxi= tax;}
return self;
}@end

// — (void) retrieveData сохраняет данные в jsonArray

//
//  ViewController.m
//  webView
//
//  Created by 1234 on 14-04-06.
//  Copyright (c) 2014 1234. All rights reserved.
//

#import "ViewController.h"#import "DetailController.h"#import "Annotation.h"

#import "City.h"
@interface ViewController (){
MKLocalSearch *localSearch;
MKLocalSearchResponse *results;
}
@property (nonatomic, strong) IBOutlet DetailController *detailViewController;@end
#define getDatalURL @"http://www.club-hop.com/apptest.php"
@implementation ViewController

@synthesize mapView,jsonArray,citiesArray;

- (void)viewDidLoad
{
[super viewDidLoad];

[self retrieveData];
self.edgesForExtendedLayout=UIRectEdgeNone;
self.detailViewController = [[DetailController alloc] init];
[self.searchDisplayController setDelegate:self];
[self.ibSearchBar setDelegate:self];
//Zoom the map to current location.
[self.mapView setShowsUserLocation:YES];
[self.mapView setUserInteractionEnabled:YES];
[self.mapView setUserTrackingMode:MKUserTrackingModeFollow];

City * cityObject;

// load external page into UIWebView
NSMutableArray * locations= [[NSMutableArray alloc]init];
CLLocationCoordinate2D location;
Annotation * myAnn;

for(int u=0; u<citiesArray.count;u++){
cityObject=[citiesArray objectAtIndex:u];

myAnn=[[Annotation alloc]init];

myAnn.city=cityObject;     // Store the city object on the annotation

NSNumber *aLat= cityObject.Latitude;
NSNumber *aLon= cityObject.Longitude;
NSString *cab= cityObject.taxi;

double lat = [aLat doubleValue];
double lon = [aLon doubleValue];

location.latitude= lat;
location.longitude=lon;
myAnn.coordinate = location;
myAnn.title=cityObject.clubName;
myAnn.subtitle=cityObject.cityName;

[locations addObject:myAnn];}

[self.mapView addAnnotations:locations];}- (BOOL)prefersStatusBarHidden
{
return YES;
}

- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}//class methods
-(void) retrieveData{

NSURL * url= [NSURL URLWithString:getDatalURL];
NSData * data= [NSData dataWithContentsOfURL:url];
jsonArray= [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:nil];

//setup cities array
citiesArray=[[NSMutableArray alloc]init];

for(int i=0; i<jsonArray.count;i++){
NSString * cID= [[jsonArray objectAtIndex:i] objectForKey:@"id"];
NSString * cName= [[jsonArray objectAtIndex:i] objectForKey:@"cityName"];
NSString * cCountry= [[jsonArray objectAtIndex:i] objectForKey:@"cityCountry"];
NSString * cLine= [[jsonArray objectAtIndex:i] objectForKey:@"clubLine"];
NSString * pri=[[jsonArray objectAtIndex:i] objectForKey:@"price"];
NSString * promo=[[jsonArray objectAtIndex:i] objectForKey:@"promo"];
NSString * camera=[[jsonArray objectAtIndex:i] objectForKey:@"camera"];
NSString * taxi= [[jsonArray objectAtIndex:i] objectForKey:@"Taxi"];
NSString * clName= [[jsonArray objectAtIndex:i] objectForKey:@"clubName"];
NSNumber * cLatitude= [[jsonArray objectAtIndex:i] objectForKey:@"Latitude"];
NSNumber * cLongitude= [[jsonArray objectAtIndex:i] objectForKey:@"Longitude"];

[citiesArray addObject:[[City alloc]initWithCityName:cName andCityCountry:cCountry   andClubName:clName andClubLine:cLine andPrice:pri andPromo:promo andCamera:camera andTaxi:taxi andLatitude:cLatitude andLongitude:cLongitude andCityId:cID]];

}

}#pragma mark - MKMapViewDelegate

// user tapped the disclosure button in the callout
//
- (void)mapView:(MKMapView *)mapView annotationView:(MKAnnotationView *)view  calloutAccessoryControlTapped:(UIControl *)control

{

UIStoryboard* storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard"bundle:nil];
self.detailViewController = [storyboard instantiateViewControllerWithIdentifier:@"Page2"];

Annotation *myAnnotation=(Annotation *)view.annotation;self.detailViewController.city=myAnnotation.city;[self.navigationController pushViewController:self.detailViewController animated:YES];}

- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id <MKAnnotation>)annotation
{
MKAnnotationView *pin=nil;
if ([annotation isKindOfClass:[Annotation class]])
{
pin=(MKAnnotationView *)[mapView   dequeueReusableAnnotationViewWithIdentifier:@"myAnnotation"];
if (pin == nil)
{
pin=[[MKAnnotationView alloc] initWithAnnotation:annotation   reuseIdentifier:@"myAnnotation"];
pin.rightCalloutAccessoryView = [UIButton buttonWithType:UIButtonTypeDetailDisclosure];
pin.image=[UIImage imageNamed:@"mappin.png"];
pin.centerOffset=CGPointMake(0.0, pin.image.size.height/-2);
pin.canShowCallout=YES;
}
}
return pin;
}#pragma mark - Search Methods

- (void)searchBarSearchButtonClicked:(UISearchBar *)searchBar {

// Cancel any previous searches.
[localSearch cancel];

// Perform a new search.
MKLocalSearchRequest *request = [[MKLocalSearchRequest alloc] init];
request.naturalLanguageQuery = searchBar.text;
request.region = self.mapView.region;

[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
localSearch = [[MKLocalSearch alloc] initWithRequest:request];

[localSearch startWithCompletionHandler:^(MKLocalSearchResponse *response, NSError *error){

[UIApplication sharedApplication].networkActivityIndicatorVisible = NO;

if (error != nil) {
[[[UIAlertView alloc] initWithTitle:NSLocalizedString(@"Map Error",nil)
message:[error localizedDescription]
delegate:nil
cancelButtonTitle:NSLocalizedString(@"OK",nil) otherButtonTitles:nil]   show];
return;
}

if ([response.mapItems count] == 0) {
[[[UIAlertView alloc] initWithTitle:NSLocalizedString(@"No Results",nil)
message:nil
delegate:nil
cancelButtonTitle:NSLocalizedString(@"OK",nil) otherButtonTitles:nil]  show];
return;
}

results = response;

[self.searchDisplayController.searchResultsTableView reloadData];
}];
}- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return [results.mapItems count];
}- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

static NSString *IDENTIFIER = @"SearchResultsCell";

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:IDENTIFIER];
if (cell == nil) {
cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:IDENTIFIER];
}

MKMapItem *item = results.mapItems[indexPath.row];

cell.textLabel.text = item.name;
cell.detailTextLabel.text = item.placemark.addressDictionary[@"Street"];

return cell;
}- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {
[self.searchDisplayController setActive:NO animated:YES];

MKMapItem *item = results.mapItems[indexPath.row];[self.mapView setCenterCoordinate:item.placemark.location.coordinate animated:YES];

[self.mapView setUserTrackingMode:MKUserTrackingModeNone];

}@end

Опять же, то, что я хотел бы сделать сейчас, это получить входные данные от пользователя и редактировать данные, полученные из http://club-hop.com/apptest.php . Любая помощь будет принята с благодарностью

2

Решение

Итак, добавление данных в БД SQL из iOS — это просто! Когда дело доходит до загрузки данных, iOS не делает слишком много работы, вы просто используете функцию HTTP POST для отправки данных в файл PHP на вашем сервере, и оттуда PHP делает тяжелую работу! Сейчас я дам вам образец:

NSString *urlString = [NSString         stringWithFormat:@"http://www.example.com/postVar.php?var=%@", hold];
NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
[request setURL:[NSURL URLWithString:urlString]];
[request setHTTPMethod:@"POST"];

NSMutableData *body= [NSMutableData data];

[request setHTTPBody:body];
NSError * e;
NSURLResponse *string;

NSData *returnData = [NSURLConnection sendSynchronousRequest:request returningResponse:&string error:&e];
NSString* returnString= [[NSString alloc] initWithData:returnData encoding:NSUTF8StringEncoding];
NSLog(@"%@", returnString);

А теперь для PHP, который будет файл с именем postVar.php

<?php
//Set Server Details
$servername = "localhost";
$username = "tester";
$dbname = "myDB";
$password = "passw0rd";
/*For security reasons, you should get your password from iOS as well, using a GET     function, but this is easier for a demo.*/
//Get Value From iOS
$var = $_GET['var'];//SQL

// Create connection
$conn = mysqli_connect($servername, $username, $password, $dbname);
// Check connection
if (!$conn) {
die("Connection failed: " . mysqli_connect_error());
}$sql = "INSERT INTO tablename (UserVariable) VALUES ('$var')";

if (mysqli_query($conn, $sql)) {
echo "Awesome. This works!";
//This is what your app will receive as the variable returnData} else {
echo "Oops. Error!";
}

mysqli_close($conn);
?>
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]