4d94a472a6fc2e79c100b382ab0ef203.ppt
- Количество слайдов: 40
Chapter 14 Building Information Systems 1
Learning Objectives § Explain the concept of a systems development life cycle (SDLC). § Compare and contrast prototyping, rapid application development (RAD), joint application design (JAD), and traditional SDLC approaches to systems development. § Identify advantages and disadvantages of objectoriented (OO) development. § Describe component-based development 2
Learning Objectives (cont. ) § Evaluate alternatives to in-house systems development. § Discuss the major strategies, methods, and tools for building e-commerce applications. § Identify advantages and disadvantages of CASE tools. § Describe alternative approaches to software process quality improvement. 3
Case: Snap-On Sets up an EC Site Problem: § Snap-On, a tool and equipment maker in Washington state wanted to set up an e-commerce site and went for the inhouse option. Solution: § Snap-On hired application service provider (ASP) On. Link Technologies to implement a catalog for the company's ecommerce site. Results: § The creation of an in-house ASP consulting service for Snap-On. § Skill transferring to other departments and subsidiaries that want to put up catalogs on their own Web sites. 4
Systems Development Life Cycle § Systems Development Life Cycle (SDLC) represents a set of general categories that show the major steps, over time, of an information systems development project. § There is no universal, standardized version of the SDLC, but the phrase has two distinct meanings. ü An SDLC can be a general conceptual framework for all the activities involved in systems development or acquisition. ü An SDLC can also be a very structured and formalized design and development process. 5
An Eight-Stage SDLC 6
Stages 1 & 2 § Stage 1: Project Initiation § Stage 2: Systems Analysis & Feasibility Studies ü Systems Analysis - the investigation of the existing situation. ü Feasibility Studies - the major areas of feasibility investigation are; • Technology • Economics • Organizational factors • Legal, ethical, and other constraints 7
Stages 3 & 4 § Stage 3: Logical Analysis and Design ü Systems analysts determine 2 major aspects of the system: (1) what it needs to do (2) how it will accomplish these functions. ü Logical Design – the design of an IS from the user’s point of view. ü Physical Design -translates the abstract logical model into the specific technical design (the “blueprints”) § Stage 4: Actual Acquisition or Development ü The logical design of the new system guides the actual development or acquisition 8
Stages 5 & 6 § Stage 5: Implementation ü Approaches to conversion from a previous system include: • • Parallel conversion Direct cutover Pilot conversion Phased (or modular) conversion § Stage 6: Operation ü After a successful conversion, the system will operate for an indefinite period of time. 9
Stages 7 & 8 § Stage 7: Post-audit Evaluation ü An organization should evaluate all its larger system projects after their completion. ü These post-audits introduce an additional element of discipline into the development process. § Stage 8: Maintenance ü Every system needs two kinds of maintenance: • Fixing bugs • Updating systems to accommodate changes in the environment 10
Implementing SDLCs IS groups considering the implementation of a formal SDLC methodology should look for the following characteristics: Ø Minimal overhead Ø Flexibility and responsiveness Ø Concurrent tasks Ø Focused analysis 11
Alternatives to Conventional SDLCs Four Possibilities: ü Prototyping ü Joint application design ü Rapid application development ü Object-oriented development 12
Prototyping 1. Instead of spending a lot of time producing very detailed specifications, the developers find out only what the users want. 2. Developers quickly create a prototype. 1. This contains portions of the system of most interest to the users, or is a small-scale working model of the entire system. 3. After reviewing the prototype with the users, the developers refine & extend it. 4. This approach is also known as evolutionary development. 13
Joint Application Design Ø Joint application design (JAD) is a group-based method for collecting user requirements and creating system designs. Ø JAD is most often used within the systems analysis and systems design stages of the SDLC. Ø In contrast to the SDLC requirements analysis, JAD has a group meeting in which all users meet simultaneously with analysts. Ø An electronic JAD session can be conducted offsite/online with technology support. ü JAD may not be an easy task for Web site design since in some cases the stakeholders may be outside of an 14 organization.
Rapid Application Development Ø Rapid application development (RAD) methodologies and tools make it possible to develop systems faster, especially systems where the user interface is an important component. Ø Typical RAD packages include the following: ü GUI development environment ü Reusable components ü Code generator ü Programming language ü E. g. , Blue Cross & Blue Shield Develop an award -winning application using RAD. 15
Rapid Application Development (cont. ) 16
Object-Oriented Development Ø An object-oriented (OO) system begins not with the task to be performed, but with the aspects of the real world that must be modeled to perform that task. Ø Object technology enables the development of purchasable, sharable, and reusable information assets (objects) existing in a worldwide network of interorganizational information systems. Ø The techniques and notations that are incorporated into a standard object-oriented language are called unified modeling language or UML. Ø The object-oriented approach is ideal for developing Web 17 applications.
Component-based Development § Components are self-contained packages of functionality that have clearly defined, open interfaces with high-level application services. ü E. g. , interface icons (small), online ordering (a business component) § Components can be distributed dynamically for reuse across multiple applications and heterogeneous computing platforms. § The major reasons for using components-based development are: ü Code reusability, which make programming faster, with fewer errors. ü Support for heterogeneous computing infrastructure and 18
Systems Developed Outside the ISD § § Many organizations are using approaches that shift the construction task from the IS department to others. Of the various ways of doing this, three are most common: Ø Let users build their own systems Ø Outsource the entire systems development process Ø Let end-users and/or the ISD use packages 19
Trends Favoring End-User Development The following list presents existing factors that lead to higher levels of end-user development: . ü Increasingly powerful desktop hardware ü Declining hardware costs ü Increasingly diverse software capabilities ü Increasingly computerliterate population ü Backlog of IS projects ü Development speed ü Business orientation ü Small applications ü Control ü Apparent cost savings 20
Outsourcing Firms that provide outsourcing cite numerous benefits: ü Hardware economies of scale ü Staffing economies of scale Outsourcing can also create problems for companies: ü Limited economies of scale ü Staffing ü Lack of business expertise ü Specialization ü Contract problems ü Tax benefits ü Internal cost reduction opportunities 21
External Acquisition of Software § The choice between developing software in-house and purchasing existing software is called the makeor-buy decision. § The initial cost of off-the-shelf software is often lower and the software should be of high quality, because many customers have used and helped debug it. § However, buying off-the-shelf software may mean that an organization has to pay for features and functions that are not needed. 22
External Acquisition of Software (cont. ) The most prominent advantages of buying off-theshelf software are: ü On-time ü On-budget ü Full functionality The following outcomes are also important: ü User acceptance ü Favorable costs-to-benefits ratio ü Low maintenance ü Scalability ü Integration with other systems ü Minimal negative crossimpacts ü Reusability 23
Managerial Considerations § The traditional SDLC approach often works well for large projects with well-defined requirements, where there is not a lot of time pressure. § Prototyping requires effective management to make sure that the iterations of prototyping do not continue indefinitely. § RAD may be less appropriate than conventional programming languages for larger projects, or those with a lot of real-time processing. § JAD is easy for senior management to understand, yet it is difficult and expensive to get all people in the same place 24 at the same time.
Managerial Considerations (cont. ) § Object-Oriented development is becoming increasingly popular, but usage is limited by a shortage of personnel with OO skills. § A component-based application architecture provides several business benefits, but the execution of component -based development requires special training and skill. § End-user development is also a possibility for larger projects whose priorities are not high enough to lead to a timely response from the central IS unit. § Outsourcing should always be considered by large and complex systems with a significant risk of failure, yet the disadvantages should be reviewed carefully. 25
The Development of EC Applications 26
The Development of EC Applications (cont. ) Step 1: System Analysis Step 2: Select a Development Option Step 3: Installation, Connection, and More Step 4: Deployment Step 5: Operation and Maintenance 27
Development Strategies for EC Applications 1. Buy the EC Applications ü The following are the major criteria for consideration in buying e-commerce applications: • • • The functionalities of development packages & criteria of choice User-friendliness Information requirements Hardware and software resources Installation Maintenance services Security Vendor quality Cost 28
Development Strategies for EC Applications 2. Lease the EC Applications ü Leasing is advantageous in cases where extensive maintenance is required, or where the cost of buying is very high. ü Two ways to lease: • • Lease the application from an outsourcer and install it on the company’s premises. Lease from either an application service provider or a CSP. 3. Develop EC Applications In House: Insourcing ü Build from scratch. ü Build from components. ü Enterprise application integration. 29
Other Development Options ØJoin An E-Marketplace ØJoin An Auction or Reverse Auction Third. Party Site ØJoint Ventures ØJoin a Consortium ØHybrid Approach 30
Application Service Provider Ø An Application service provider (ASP) is an agent who assembles functionality needed by enterprises, and packages it with outsourced development, operation, maintenance, and other services. Ø The essential difference between an ASP and an outsourcer is that an ASP will manage application servers in a centrally controlled location, rather than on a customer’s site. 31
Benefits & Risks of ASP Leasing Type Benefit Potential Risk Busines s Reduces the need to attract and retain skilled IT professionals. Loss of control and high level of dependence on ASP. Enables company to concentrate on strategic use of IT. Inability of ASP to deliver quality of service: lack of skills and experience. Fast and easy application deployment. Level of customization and legacy application integration offered by ASP may be insufficient. Technic al Higher degree of Reliability and speed of delivery application standardization. due to bandwidth limitations. Econom Low total cost of ownership. Pricing changes by ASP ic unpredictable for application updates and services. 32
Criteria for Selecting an ASP Vendor Ø Track record Ø Support services Ø Scope of service Ø Integration Ø Application & data storage Ø Database format & portability 33
Java Programming Language § Java has established itself as the most important programming language for putting extra features into Web pages. ü Java is an object-oriented language. ü The Java Web page programs, called applets, need to be relatively small to avoid delays in transmitting them over the Internet. ü Prototyping is probably the most suitable approach for developing Java applets. 34
CASE Tools Ø Computer-aided software engineering (CASE) tools are marketed as individual items or in a set (toolkit) that automates various aspects of the development process. Ø CASE can be used in two different ways: ü To automate certain SDLC activities on a piecemeal basis. ü To provide an integrated (I-CASE) package for IS groups. Ø The relatively high turnover rate among systems personnel creates problems for use of I-CASE systems as new employees will need to take the time to learn the integrated package. 35
Software Quality Ø The International Organization for Standardization (ISO) first published its quality standards in 1987, and then republished an updated version in 2000. Ø The ISO allows organizations to use any SDLC that includes the Contract review ü Testing and validation ü following: ü Purchaser’s requirements specification ü Development planning ü Quality planning ü Design and implementation ü Acceptance ü Replication, delivery, and installation ü Maintenance 36
Project Planning § Project planning provides an overall framework with which the systems development life cycle can be planned, scheduled, and controlled. § Milestones, or checkpoints, are established to allow a periodic review of progress. 37
Project Planning (cont. ) § Critical Path Method (CPM), PERT, and Gantt Charts. ü These generic project management tools are suitable for systems development projects. § Project Properties and Priorities ü The following five properties most significantly influence the overall nature of an IT project: • • • Predefined structure Stability of technology Size User proficiency Developer proficiency 38
Managerial Issues 1. Importance. Functional managers must participate in the development process and should understand all the phases. 2. Ethical and legal issues. Developing systems across organizations and countries could result in problems in any phase of system development. ü Building interorganizational and international information systems can be very complicated. 39
Managerial Issues (cont. ) ü User involvement is important. ü Traditional approaches vs. prototyping. ü Tool use by developers. ü Quality assurance vs. schedules. ü Behavior problems. ü Perpetual development. 40
4d94a472a6fc2e79c100b382ab0ef203.ppt